龙空技术网

国际银行都在用安全算法—RSA,多少黑客为这个算法而折腰

python猿 574

前言:

此刻咱们对“rsa算法的密钥长度至少1024位才能保证其安全性”可能比较关注,朋友们都需要知道一些“rsa算法的密钥长度至少1024位才能保证其安全性”的相关文章。那么小编在网上汇集了一些关于“rsa算法的密钥长度至少1024位才能保证其安全性””的相关资讯,希望同学们能喜欢,我们一起来了解一下吧!

RSA概述

首先看这个加密算法的命名.很有意思,它其实是三个人的名字.早在1977年由麻省理工学院的三位数学家Rivest、Shamir 和 Adleman一起提出了这个加密算法,并且用他们三个人姓氏开头字母命名.

RSA加密算法是一种非对称加密算法,其玩法打破了以往所有加密算法的规则.在RSA出现之前,所有的加密方法都是同一种模式:加密解密的规则使用同一种方式.这种长达几个世纪的加密方案有一个致命的缺陷.在传递加密信息时,必须让对方拿到解密的规则才能正常解密.由于加密解密的规则一致,所以保存和传递"密钥",就成了最头疼的问题。

RSA的出现解决了这个问题.我们来看看RSA是怎么玩的.

RSA加密/解密使用公钥加密的数据,利用私钥进行解密使用私钥加密的数据,利用公钥进行解密

没错,RSA加密使用了"一对"密钥.分别是公钥和私钥,这个公钥和私钥其实就是一组数字!其二进制位长度可以是1024位或者2048位.长度越长其加密强度越大,目前为止公之于众的能破解的最大长度为768位密钥,只要高于768位,相对就比较安全.所以目前为止,这种加密算法一直被广泛使用.

RSA的弊端

由于RSA算法的原理都是大数计算,使得RSA最快的情况也比对称加密算法慢上好几倍。速度一直是RSA的缺陷,一般来说RSA只用于小数据的加密.RSA的速度是对应同样安全级别的对称加密算法的1/1000左右。

RSA终端命令演示

由于Mac系统内置OpenSSL(开源加密库),所以我们可以直接在终端上使用命令来玩RSA.

OpenSSL中RSA算法常用指令主要有三个,其他指令此处不介绍。

生成RSA私钥,密钥长度为1024bit

从私钥中提取公钥

我们可以看到生成的私钥和公钥文件如下图:

显得非常高大上对吧!那么它里面是什么,我们可以利用终端进行查看.

其实就是一个文本文件,并且一看就知道是base64编码.那么公钥相比私钥要简单很多.我们可以通过命令,将私钥转换成为明文看看.

通过公钥加密数据,私钥解密数据

通过私钥加密数据,公钥解密数据

小结

那么看到这些之后,对RSA应该有了一定的了解.由于RSA加密运行效率非常低!并不是所有数据加密都会使用它.那么它的主战场在于加密一些小的数据,比如对称加密算法的密钥.又或者数字签名.关于数字签名后续文章我们再详细阐述.

标签: #rsa算法的密钥长度至少1024位才能保证其安全性