[网络工程师]-网络安全-数字签名和数字证书

news2024/10/6 2:20:18

        随着《中华人民共和国电子签名法》这部法律的出台和实施,电子签名获得了与传统手写签名和盖章同等的法律效力,这意味着经过电子签名的电子文档在网上传输有了合法性。电子签名并非是书面签名的数字图像化,而是一种电子代码。联合国贸发会的《电子签名示范法》对电子签名作出如下定义:“指在数据电文中以电子形式所含、所附或在逻辑上与数据电文有联系的数据,它用于鉴别与数据电文相关的签名人和表明签名人认可数据电文所含信息”。

1、数字签名

        数字签名是电子签名的一种,它要求:发送者事后不能否认发送的报文签名、接收者能够核实发送者发送的报文签名、接收者不能伪造发送者的报文签名、接收者不能对发送者的报文进行部分篡改、网络中的某一用户不能冒充另一用户作为发送者或接收者。

        数字签名主要用于确保A发送给B的信息就是A本人发送的,并且没有改动。数字签名和验证的过程如下所示:

        数字签名的基本过程:

        (1)A使用“摘要”算法(如SHA-1、MD5等)对发送信息进行摘要;

        (2)使用A的私钥对消息摘要进行加密运算,将加密摘要和原文一并发给B;

        验证签名的基本过程:

        (1)B收到加密摘要和原文后,使用和A一样的“摘要”算法对原文再次摘要,生成新摘要;

        (2)使用A公钥对加密摘要解密,还原成原摘要;

        (3)两个摘要对比,一致则说明由A发出且没有进过任何篡改。

2、数字证书

        数字证书采用公钥体制进行加密和解密,每个用户有一个私钥来解密和签名,同时每个用户还有一个公钥来加密和验证。

        可以通过例子说明数字证书、CA签名、证书公钥的作用:假如某网站向证书颁发机构(Certification Authority,CA)申请了数字证书,用户通过CA的签名来验证网站的真伪。在用户与网站进行安全通信时,用户可以通过证书中的公钥进行加密和验证,该网站通过网站的私钥进行解密和签名。

        (1)X.509格式

        目前数字证书的格式大多是X.509格式,X.509是由国际电信联盟(ITU-T)制定的数字证书标准。在此标准中,包含在数字证书中的数据域有证书、版本号、序列号(唯一标识每一个CA下发的证书)、算法标识、颁发者、有效期、有效起始日期、有效终止日期、使用者、使用者公钥信息、公钥算法、公钥、颁发者唯一标识、使用者唯一标识、扩展、证书签名算法、证书签名(发证机构,即CA用自己私钥对用户证书进行签名防止篡改)。

        (2)证书发放

        证书由CA中心发放,无需特别措施。由于网络中存在多个CA中心,因此提出了“证书链”概念。证书链服务是一个CA扩展其信任范围的机制,实现不同认证中心发放的证书的信息交换。如果用户UA从A地的发证机构取得了证书,用户UB从B地的发证机构取得了证书,那么UA通过证书链交换了证书信息,则可以与UB进行安全通信。

        (3)证书吊销

        当用户个人身份信息发生变化或私钥丢失、泄露、疑似泄露时,证书用户应及时向CA提出证书的撤销请求,CA也应及时将此证书放入公开发布的证书撤销列表(Certification Revocation List,CRL)。

        证书撤销的流程为:

        1)用户或其上级单位向注册机构(Registration Authority,RA)提出撤销请求;

        2)RA审查撤销请求;

        3)审查通过后,RA将撤销请求发送给CA或CRL签发机构;

        4)CA或CRL签发机构修改证书状态并签发新的CRL。

        当该数字证书被放入CRL后,数字证书则被认为失效,而失效并不意味着无法被使用。如果乙窃取到甲的私钥,用甲的私钥签名了一份文件发送给丙,并附上甲的证书,而丙忽视了对CRL的查看,丙就会用甲的证书成功验证这份非法的签名,并认为甲对这份文件签过名而接收该文件,由此会导致网络安全问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/81570.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

单源最短路径问题——分支限界法(Java)

单源最短路径问题——分支限界法(Java) 文章目录单源最短路径问题——分支限界法(Java)1、 前置芝士1.1 分支限界法求解目标1.2 分支限界法引言1.3 分支限界法基本思想1.4 两种典型的解空间树2、分支限界法解题过程2.1 算法要点2.…

java 实现对数据表的备份与还原(备份与还原 到服务器中)

java备份还原表数据 背景 需求:这个功能还是费了我一段时间才完成,大体的需求是这样的。 首先是 分模块,每个模块有不同的几个表,备份的时候就按照模块来备份数据,相当于一次性备份多张表的数据了,模块 和…

攻防世界-baigeiRSA

1.下载附件,得到压缩包,解压得到两个文件。 import libnum from Crypto.Util import number from secret import flagsize 128 e 65537 p number.getPrime(size) q number.getPrime(size) n p*qm libnum.s2n(flag) c pow(m, e, n)print(n %d % …

(已更新)Discuz手机模板:NVBING5-APP手机版,界面美观大方,可封装安卓/苹果APP,模板文件+插件+分类信息导入文件

Discuz手机模板:NVBING5-APP手机版——是一款界面美观大方的完整Discuz手机模板,附带模板插件分类信息导入文件详细的安装说明模块说明。 功能介绍 *支持封装安卓APP、苹果APP,原生微信登录、分享等几十项功能 *支持视频上传至优酷云或本地…

水溶性荧光团磺酸基-花青素Cy7 酪酰胺,Tyramide-Sulfo-Cy7

磺酸基-花青素Cy7 酪酰胺是一种水溶性荧光团,用于近红外光谱部分。由于其结构中存在三亚甲基桥,使其量子产率比其他七甲基菁高。氟化染料是理想的体内成像应用。一个非氟化版本,Cyanine7,也可用。 『英文名称』:Tyram…

基础SQL语法语句大全(一篇学会所有SQL语句)

如:select distinct name from student; 如:select name,salary from employee where deptno 3; 如:select * from employees where deptno 3 and salary>-5000;(两个条件同时满足) select * from employees where (deptno 3 or depton…

HARDiNFO Pro 8.0 绿色版-轻便版

HARDiNFO 一体化系统信息、诊断和基准测试 主要特点 硬件清单、计算机管理、基准测试和网络监控 硬件库存 获取有关您的 PC 硬件组件和外围设备的详细系统信息,例如;CPU、内存、主板、显示适配器、HDD/SSD 磁盘驱动器、显示器、笔记本电池、操作系统驱动…

[附源码]JAVA毕业设计医院门诊挂号系统(系统+LW)

[附源码]JAVA毕业设计医院门诊挂号系统(系统LW) 项目运行 环境项配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术…

【QT 5 学习笔记-学习绘图相关+画线图形等+绘图事件+基础学习(1)】

【QT 5 学习笔记-学习绘图相关画线图形等绘图事件基础学习(1)】1、说明2、实验环境3、参照学习链接4、自己的学习与理解5、学习与实践代码。(1)建立基础工程。(2)加入绘图事件与包含库(3&#x…

自然语言处理(NLP)数据集汇总 2(附下载链接)

🎄🎄【自然语言处理NLP】简介 🎄🎄 自然语言处理(Natural Language Processing, NLP)是计算机科学领域与人工智能领域中的一个重要方向。它研究能实现人与计算机之间用自然语言进行有效通信的各种理论和方法。自然语言处理是一门…

真是绝了!git标星9K

能力f(认知,洞察,实践,经验总结) 不知道你到了哪个阶段了呢? 架构是软件工程的实践艺术,要化理想为现实,不是空中楼阁。懂得再多的设计理念、方法论,光说不练还是假把式…

大二学生《Web编程基础》期末网页制作 HTML+CSS个人网页设计实例

🎉精彩专栏推荐👇🏻👇🏻👇🏻 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 💂 作者主页: 【主页——🚀获取更多优质源码】 🎓 web前端期末大作业…

8年前端带你HTML+CSS入门到实战(附视频+源码)

本文主要是解决: ☆ 想要自学前端开发, ☆ 但又不太想看博客文章, ☆ 觉得自学有点吃力,有点不知道学习步骤的同学 目录 一、HTML 1、需要了解熟练的标签 2、不太常用的标签 3、怎么算是HTML学好了,可以继续学CSS了…

ChatGPT教你面试阿里P6测试开发岗

​持续坚持原创输出,点击蓝字关注我吧 最近ChatGPT爆火,ChatGPT能干什么呢?想必已经看过很多文章了,例如ChatGPT通过美国高考、ChatGPT开发游戏、调试代码、写文章等等。 哈哈,作为一个软件测试博主,我怎么…

Java和MySQL的连接和操作(JDBC)

一、数据库的连接 1. 引入JDBC驱动程序 1.1 如何获取驱动程序 驱动程序由数据库提供商提供下载。 MySQL 的驱动下载地址:http://dev.mysql.com/downloads/ 依次点击 Connector/J -> Platform Independent ,如然后下载下面那个 1.2 如何在Java …

ADI Blackfin DSP处理器-BF533的开发详解25:LCD_ZIKU(字库在液晶屏上的应用)(含源代码)

硬件准备 ADSP-EDU-BF533:BF533开发板 AD-HP530ICE:ADI DSP仿真器 软件准备 Visual DSP软件 硬件链接 功能介绍 代码实现了将字库信息显示到液晶屏上。 代码使用说明 增加了液晶屏驱动,将内存数据显示到液晶屏上。 内存数据转换&…

[附源码]Python计算机毕业设计大学生兼职推荐系统Django(程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 项目运行 环境配置: Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术: django python Vue 等等组成,B/S模式 pychram管理等…

Git从入门到实战

Git从入门到实战 一、Git概述 1.1、Git简介 Git是一个分布式版本控制工具,通常用来对软件开发过程中的源代码文件进行管理。Git仓库来存储和管理这些文件,Git仓库分为两种: 本地仓库:开发人员自己电脑上的Git仓库远程仓库&…

微服务框架 SpringCloud微服务架构 微服务保护 32 隔离和降级 32.1 Feign整合Sentinel

微服务框架 【SpringCloudRabbitMQDockerRedis搜索分布式,系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】 微服务保护 文章目录微服务框架微服务保护32 隔离和降级32.1 Feign整合Sentinel32.1.1 隔离和降级32.1.2 Feign 整合Sentinel32.1.3 总结32 …

算法设计与分析期末复习(一)

算法的定义和特征 什么是算法? 算法是求解某一特定问题的一组有穷规则的集合,它是由若干条指令组成的有穷符号串。算法的五个重要特性 确定性:算法中每一条指令必须有确切的含义,不存在二义性。只有一个入口和一个出口。 可行性&…