几种常见加密算法初窥及如何选用加密算法
来源:互联网 发布:udp端口怎么测试 编辑:程序博客网 时间:2024/06/04 23:08
加密算法通常分为对称性加密算法和非对称性加密算法,对于对称性加密算法,信息接收双方都需事先知道密匙和加解密算法且其密匙是相同的,之后便是对数据进行加解密了。非对称算法与之不同,发送双方A,B事先均生成一堆密匙,然后A将自己的公有密匙发送给B,B将自己的公有密匙发送给A,如果A要给B发送消息,则先需要用B的公有密匙进行消息加密,然后发送给B端,此时B端再用自己的私有密匙进行消息解密,B向A发送消息时为同样的道理。
对称性加密算法:DES,3DES,AES
DES
DES算法为密码体制中的对称密码体制,又被称为美国数据加密标准,是1972年美国IBM公司研制的对称密码体制加密算法。 明文按64位进行分组,密钥长64位,密钥事实上是56位参与DES运算(第8、16、24、32、40、48、56、64位是校验位, 使得每个密钥都有奇数个1)分组后的明文组和56位的密钥按位替代或交换的方法形成密文组的加密方法。
其入口参数有三个:key、data、mode。key为加密解密使用的密钥,data为加密解密的数据,mode为其工作模式。当模式为加密模式时,明文按照64位进行分组,形成明文组,key用于对数据加密,当模式为解密模式时,key用于对数据解密。实际运用中,密钥只用到了64位中的56位,这样才具有高的安全性。
3DES
非对称性加密算法:RSA,DSA,ECC
RSA和DSA的安全性及其它各方面性能都差不多,而ECC较之则有着很多的性能优越,包括处理速度,带宽要求,存储空间等等。
几种线性散列算法(签名算法):MD5,SHA1,HMAC
这几种算法只生成一串不可逆的密文,经常用其效验数据传输过程中是否经过修改,因为相同的生成算法对于同一明文只会生成唯一的密文,若相同算法生成的密文不同,则证明传输数据进行过了修改。通常在数据传说过程前,使用MD5和SHA1算法均需要发送和接收数据双方在数据传送之前就知道密匙生成算法,而HMAC与之不同的是需要生成一个密匙,发送方用此密匙对数据进行摘要处理(生成密文),接收方再利用此密匙对接收到的数据进行摘要处理,再判断生成的密文是否相同。
对于各种加密算法的选用:
由于对称加密算法的密钥管理是一个复杂的过程,密钥的管理直接决定着他的安全性,因此当数据量很小时,我们可以考虑采用非对称加密算法。
在实际的操作过程中,我们通常采用的方式是:采用非对称加密算法管理对称算法的密钥,然后用对称加密算法加密数据,这样我们就集成了两类加密算法的优点,既实现了加密速度快的优点,又实现了安全方便管理密钥的优点。
如果在选定了加密算法后,那采用多少位的密钥呢?一般来说,密钥越长,运行的速度就越慢,应该根据的我们实际需要的安全级别来选择,一般来说,RSA建议采用1024位的数字,ECC建议采用160位,AES采用128为即可。
Base64编码
Base64编码要求把3个8位字节(3*8=24)转化为4个6位的字节(4*6=24),之后在6位的前面补两个0,形成8位一个字节的形式。由于2的6次方为64,所以每6个位为一个单元,对应某个可打印字符。当原数据不是3的整数倍时,Base64用\x00
字节在末尾补足后,再在编码的末尾加上1个或2个=
号,表示补了多少字节,解码的时候,会自动去掉。如果最后剩下两个输入数据,在编码结果后加1个“=;如果最后剩下一个输入数据,编码结果后加2个“=;如果没有剩下任何数据,就什么都不要加,这样才可以保证资料还原的正确性
- 几种常见加密算法初窥及如何选用加密算法
- 几种常见加密算法初窥及如何选用加密算法
- 几种常见加密算法初窥及如何选用加密算法
- 几种常见加密算法初窥及如何选用加密算法
- 几种常见加密算法初窥及如何选用加密算法(AES,DES,3DES)
- 几种常见加密算法
- 几种常见加密算法解析及使用
- 几种常见加密算法解析及使用
- JAVA 几种常见加密算法
- SSL协议和几种常见加密算法
- 常见的几种安全加密算法
- 加密算法介绍及如何选择加密算法
- [转]加密算法介绍及如何选择加密算法
- 加密算法介绍及如何选择加密算法
- 几种JAVA加密算法
- 几种JAVA加密算法
- 几种JAVA加密算法
- 几种JAVA加密算法
- c++第1次上机实验-2
- 我的代理,block
- Android studio中java控制台输出中文乱码
- 接口回调
- CODEFORCES630F-Selection of Personnel
- 几种常见加密算法初窥及如何选用加密算法
- 微服务实战(一):微服务架构的优势与不足
- javaWeb-Servlet之Filter(过滤器二)
- Java集合:Hashtable使用详解及源码分析
- PAT (Advanced Level) Practise 1034 Head of a Gang (30)
- MongoDB Replica Set配置
- Fragment详解之五——Fragment间参数传递
- 值得学习的C语言开源项目
- Js获取当前日期时间及其它操作