说说签名与验签

简介

本文会比较简短

目的很简单

就是提升自己对【签名】与【验签】的熟悉程度 ------ 熟悉签名、验签的【整体流程】

正文

签名简介

【签名】用于验证消息来源和完整性。需配合哈希算法(如 SHA-256)和密钥对(用私钥签名,用公钥验证)。

它只用于非对称加密(也就是发送方和接收方分别有自己的公钥和私钥)

签名和验签的流程【这是最重要的部分,要十分熟练】

发送方(签名):

a. 对原始消息计算哈希值(摘要)。

b. 使用发送方自己的私钥,对这个哈希值进行签名运算,生成数字签名。

c. 将【原始消息】和【数字签名】一起发送给接收方。

接收方(验签):

a. 接收后,将收到的内容分离成【原始消息】和【数字签名】两部分。

b. 使用发送方的公钥对数字签名进行【验签】运算,从而解出一个哈希值 H1。【⚠️⚠️ 注意,这边说的是验签,这个词会比"解密"更精准】

c. 最关键的一步: 使用【相同的哈希算法】,对收到的原始消息单独计算一次哈希值 H2。【⚠️⚠️ 注意,也就是双方的哈希算法是提前约定好的】

d. 将计算得到的 H2 与从签名中解出的 H1 进行比对。

如果 H1 == H2:验签成功!证明:1. 消息确实来自发送方(认证性)。2. 消息在传输中未被篡改(完整性)。

如果 H1 != H2:验签失败!证明消息要么被篡改,要么不是声称的发送方所发。

最后

此前只注意"签名"这个词,不太注意"验签"这个词

导致最开始在看一些内容的时候有点懵

特此总结!

相关推荐
Victor35613 小时前
https://editor.csdn.net/md/?articleId=139321571&spm=1011.2415.3001.9698
后端
Victor35613 小时前
Hibernate(89)如何在压力测试中使用Hibernate?
后端
灰子学技术14 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
Gogo81615 小时前
BigInt 与 Number 的爱恨情仇,为何大佬都劝你“能用 Number 就别用 BigInt”?
后端
fuquxiaoguang15 小时前
深入浅出:使用MDC构建SpringBoot全链路请求追踪系统
java·spring boot·后端·调用链分析
毕设源码_廖学姐16 小时前
计算机毕业设计springboot招聘系统网站 基于SpringBoot的在线人才对接平台 SpringBoot驱动的智能求职与招聘服务网
spring boot·后端·课程设计
野犬寒鸦17 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
逍遥德18 小时前
如何学编程之01.理论篇.如何通过阅读代码来提高自己的编程能力?
前端·后端·程序人生·重构·软件构建·代码规范
MX_935919 小时前
Spring的bean工厂后处理器和Bean后处理器
java·后端·spring
程序员泠零澪回家种桔子19 小时前
Spring AI框架全方位详解
java·人工智能·后端·spring·ai·架构