RSA的运用和前后端签名的一些看法_rsa puk pvk-程序员宅基地

技术标签: rsa  java  服务器开发  

RSA在验签过程的使用场景分析

	RSA的文章有很多。原理性学术性的对于我这样普通的码农毫无意义,对于我来说,我只想知道为什么我们要用RSA,以及什么
	情况下我们需要使用它?这是一篇粗浅且迅速入门的文章。

首先,我要介绍RSA验签的流程,稍后再分析为啥要这样做。
场景是存在(A)要传输数据给(B)。为方便起见,我们把数据称为(R)。
此时:A与B各自持有自己的privateKey,以及公之于众的publicKey(由RSA算法生成)。以下我们简称PVK(A)、PVK(B)、PUK(A)、PUK(B)。
A:
①使用某种算法给数据加密,通常会是MD5。我们得到密文M(R)。
②A对M(R)使用PVK(A)加密,得到RSA(M(R))。
③把RSA(M(R)) + R 这样的组合使用B公布的PUK(B)加密,得到最终的密文,简称F(R)。
B:
①B使用PVK(B)解密F(R)得到 RSA(M(R)) + R
到这一步,B已经拿到需要的R了,但是,他不知道R是否是A传来的,需要验签。
②B使用A公布的PUK(A)解密RSA(M(R))得到M(R)
③B使用MD5算法对R加密,得到M(R),比较两个M(R)是否一致,若一致,则验签成功。

不按照上述方式验签会造成的问题

那么假如上述方案去掉几步,会不会就不能成功验签了呢?
那我们不妨做一些假设。假如我就是不法分子C,伪造数据与B通信。

场景①:A只用了PUK(B)加密,B用PVK(B)解密。也就是所有操作阉割得只剩1步。
C:因为PUK(B)是公之于众的,所以我把伪造数据C也使用PUK(B)加密即可。

场景②:A使用PUK(B)加密(M(R)+R)的密文,用于MD5校验,是否能阻止C呢?
C:显而易见。我对(M(C)+C)使用PUK(B)加密,B解密后,依然无法验证C是否是正确的数据。

场景③:也就是按照上述流程,在M(R)上再套一层PVK(A)加密,会怎么样呢?
C:因为C没有PVK(A),只有PVK(C),所以B用PUK(A)无法解密RSA(M(C)),识破了C的阴谋。

日常前后端交互简化版的RSA应用分析

假如只是系统内部验签,其实不用这么麻烦。服务器A与B只需要各自约定加密方式即可。

最简化版的是:
A:
①对R做一些约定好的操作,生成R2。
②使用MD5加密,得到M(R2)。
③发送M(R2)+R

B:
①对R做相同的操作,生成R2。
②使用MD5加密,得到M(R2)。
③验证M(R2)是否相同,若相同,则验签成功。

但是这样的系统存在一些问题。
假如只有两个系统,那么没问题。但是假如有A、B、C、D、E、F等等,系统很多的话,他们之间的加密规则会变混乱,也许EF通信错转发数据给了A,A也顺利验签通过。所以我们需要给AB、AC、AD、AE、AF、BC …都建立一套新R约定的规则,过于麻烦。因此RSA此时就是这样一个规范且不需要额外记忆的规则。

因此我们在上述步骤中,对M(R2)再使用PVK(AB)加密,得到RSA(M(R2))。(验签始终使用PVK加密,这样不法分子C无法对数据伪造。)
这样,B端就可以使用和A约定好的PUK(AB)解密数据,再使用MD5验签了。

我总结一下RSA:
①假如传输数据不能被第三方看见,则用PUK加密。反过来,用什么都行。
②验签只能使用PVK加密,这样才能防止伪造数据。
因此RSA很好理解,就是PVK加密用于防止伪造,再用PUK加密用来隐藏数据。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/chenyezhou1/article/details/83375439

智能推荐

Linux之shell中的case in语句_linux case in-程序员宅基地

文章浏览阅读2.7k次,点赞2次,收藏15次。文章目录shell中的case in 语句1.case in 的用法2.case in和正则表达式shell中的case in 语句1.case in 的用法格式: 1 | case expression in 2 | PAT1) 3 | 执行语句 4 | ;; 5 | PAT2) 6 | 执行语句 7 | ;; 8 | *..._linux case in

rv1126-rv1109-RkLunch.sh_rkipc-程序员宅基地

文章浏览阅读423次。RkLunch.sh是个脚本剖析rkipc的调用这个APP_rkipc

C#中实现拖放操作-程序员宅基地

文章浏览阅读480次。随着桌面系统的推出,利用鼠标的拖放(Drag and Drop)操作由于其简单、直接,受到了越来越多的读者的欢迎,为迎合这种趋势,越来越多程序员在自己的程序中使用了拖放操作。拖放操作方便了程序的使用者,但由于拖放操作在程序中的设计工作比较还有点麻烦,甚至是一个难点,许多程序员对其都有点心有余悸。本文就结合微软公司最新的.Net程序开发语言--C#,来全面介绍一下在C#中是如何处理拖放操作的。

操作系统第二章进程管理习题及其答案-程序员宅基地

文章浏览阅读467次,点赞7次,收藏20次。一、选择题一个运行进程必须具有的 3 种基本状态是(C)A.就绪状态、挂起状态和执行状态 C.就绪状态、执行状态和阻塞状态进程和程序的根本区别在于( A)。A.静态与动态特点B.是不是被调入到内存中C.是不是具有就绪、运行和等待三种状态D.是不是占有处理器下面所列的进程的 3 种基本状态之间的转换不正确的是(D )。A.就绪状态→执行状态B.执行状态→就绪状态C.执行状态→...

JAVA实现的基于内容的图像检索系统设计与实现_java图像检索系统实现-程序员宅基地

文章浏览阅读1.2k次。1 图像检索系统工作流程基于内容的图像检索技术是对输入的图像进行分析并分类统一建模,提取其颜色、形状、纹理、轮廓和空间位置等特征,建立特征索引, 存储于特征数据库中。检索时,用户提交查询的源图像,通过用户接口设置查询条件,可以采用一种或几种的特征组合来表示,然后在图像数据库中提取出查询到的所需关联图像,按照相似度从大到小的顺序,反馈给用户。用户可根据自己的满意程度,选择是否修改查询条件,继续查..._java图像检索系统实现

可靠UDP,KCP协议快在哪?-程序员宅基地

文章浏览阅读71次。WeTest 导读云真机已经支持手机端的画面投影。云真机实时操作,对延迟的要求比远程视频对话的要求更高(100ms以内)。在无线网络下,如何更实时、更可靠的传输视频流就成了一个挑战。通过websocket、RTMP、UDP的比较,最后选择了可靠的UDP协议KCP来进行实时音视频的传输。1 简介KCP是一个快速可靠协议,能以比 TCP浪费10%-20%的带宽的代..._udp快在哪里

随便推点

基于支持向量机结合AdaBoost时间序列预测模型研究附MATLAB代码-程序员宅基地

文章浏览阅读737次,点赞25次,收藏22次。作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,????个人主页:Matlab科研工作室????个人信条:格物致知。更多Matlab完整代码及仿真定制内容点击????智能优化算法 神经网络预测 雷达通信 无线传感器 电力系统信号处理 图像处理 ...

考研复试面试专业问题_控制管理模块写在哪个文件-程序员宅基地

文章浏览阅读5.6k次,点赞14次,收藏68次。中科大复试准备数据结构->操作系统->计算机网络->通信原理->微机原理->软件工程,编译原理,数据库计算机考研复试整理PDF文件自取数据结构1. 时间复杂度时间复杂度是指执行算法所需要的计算工作量,因为整个算法的执行时间与基本操作重复执行的次数成正比,所以将算法中基本操作的次数作为算法时间复杂度的度量,一般情况下,按照基本操作次数最多的输..._控制管理模块写在哪个文件

三本建筑学与计算机专业,填报三本志愿最适合选择这三个专业,毕业后前景不输重点本科生...-程序员宅基地

文章浏览阅读588次。虽然三本院校处在本科阶段最末端的排名,但是并不代表大家选择了三本就不会比其他本科生差,那么小编今天为大家准备了这篇填报三本志愿最适合选择这三个专业,毕业后前景不输重点本科生的相关讲解,大家一定要认真学习。计算机专业计算机影响人类生活这句话相信现在每一位学生都体会到了,但是目前计算机行业依然在飞速发展中,作为一个技术性的专业工资待遇当然是比较理想的,月薪上万也属实是一个普通水平。如果三本学生将计算机..._三本建筑学没出路吗

杰里之各个IC 测试功耗表(693X-697X)_杰里 6973 pdf-程序员宅基地

文章浏览阅读2.8k次。示例:6956A:其他芯片的数据待传:文件比较大,可以多问小编!_杰里 6973 pdf

后台向前台输出 换行“\n”-程序员宅基地

文章浏览阅读775次。MVC 中后台向前台输出 “\n”总是报错因为后台向前台输出 “\n” 后,前台出现换行eg: "这里是\n换行"var str="这里是换行";这里的\n被翻译成换行,这个变量就出现问题了!可以在后台输出时把"\n"替换成 <br/>转载于:https://www.cnblogs.com/xbblogs/p/6166002.html..._数据库里存的是\n 为什么传到前台是\\n

Excel和CSV格式文件的不同之处_exelce表格是csv文件吗-程序员宅基地

文章浏览阅读7.4w次,点赞28次,收藏85次。Excel和CSV格式文件的不同之处来源:https://www.guru99.com/excel-vs-csv.htmlExcelCSV这是一个二进制文件,它保存有关工作簿中所有工作表的信息CSV代表CommaSeparatedValues。这是一个纯文本格式,用逗号分隔一系列值_exelce表格是csv文件吗