常见的加密算法可以分成三类,对称加密算法,非对称加密算法和Hash算法。
对称加密
指加密和解密使用相同密钥的加密算法。对称加密算法的优点在于加解密的高速度和使用长密钥时的难破解性。假设两个用户需要使用对称加密方法加密然后交换数据,则用户最少需要2个密钥并交换使用,如果企业内用户有n个,则整个企业共需要n×(n-1) 个密钥,密钥的生成和分发将成为企业信息部门的恶梦。对称加密算法的安全性取决于加密密钥的保存情况,但要求企业中每一个持有密钥的人都保守祕密是不可能的,他们通常会有意无意的把密钥泄漏出去——如果一个用户使用的密钥被入侵者所获得,入侵者便可以读取该用户密钥加密的所有文档,如果整个企业共用一个加密密钥,那整个企业文档的保密性便无从谈起。
常见的对称加密算法:DES、3DES、DESX、Blowfish、IDEA、RC4、RC5、RC6和AES
非对称加密
指加密和解密使用不同密钥的加密算法,也称为公私钥加密。假设两个用户要加密交换数据,双方交换公钥,使用时一方用对方的公钥加密,另一方即可用自己的私钥解密。如果企业中有n个用户,企业需要生成n对密钥,并分发n个公钥。由于公钥是可以公开的,用户只要保管好自己的私钥即可,因此加密密钥的分发将变得十分简单。同时,由于每个用户的私钥是唯一的,其他用户除了可以可以通过信息发送者的公钥来验证信息的来源是否真实,还可以确保发送者无法否认曾发送过该信息。非对称加密的缺点是加解密速度要远远慢于对称加密,在某些极端情况下,甚至能比非对称加密慢上1000倍。
常见的非对称加密算法:RSA、ECC(移动设备用)、Diffie-Hellman、El Gamal、DSA(数字签名用)
Hash算法
Hash算法特别的地方在于它是一种单向算法,用户可以通过Hash算法对目标信息生成一段特定长度的唯一的Hash值,却不能通过这个Hash值重新获得目标信息。因此Hash算法常用在不可还原的密码存储、信息完整性校验等。
常见的Hash算法:MD2、MD4、MD5、HAVAL、SHA、SHA-1、HMAC、HMAC-MD5、HMAC-SHA1
加密算法的效能通常可以按照算法本身的复杂程度、密钥长度(密钥越长越安全)、加解密速度等来衡量。上述的算法中,除了DES密钥长度不够、MD2速度较慢已逐渐被淘汰外,其他算法仍在目前的加密系统产品中使用。
MD5的典型应用是对一段Message(字节串)产生fingerprint(指纹/摘要),以防止被“篡改”。
摘要算法是不可逆的,他的主要作用是对信息一致性和完整性的校验。而对称加密算法是可逆的,它的主要作用是保证私密信息不被泄露。
参考:
http://www.cnblogs.com/colife/p/5566789.html
MD5–http://mp.weixin.qq.com/s?__biz=MzI1MTIzMzI2MA==&mid=2650561400&idx=1&sn=4b70e39b1c30ccfddd148eeee50d9519&chksm=f1feedfbc68964ed463d83e88bde0ed175077e113beaa582e6bd5968da3c39145c8cec2e7889&mpshare=1&scene=24&srcid=10171okLlI8aRlbzakFeSQqS#rd
SHA–http://mp.weixin.qq.com/s?__biz=MzI1MTIzMzI2MA==&mid=2650561442&idx=1&sn=0bbb6ea44e4b4feb6b3257a3dd0e2990&chksm=f1feed21c68964375afea60d46bea99dc1ad7bf3ff047086c9a974230982791b44ae3f85e7b4&mpshare=1&scene=24&srcid=10170P9fjzinK2nVCQZfLRL9#rd
Base-64–http://mp.weixin.qq.com/s?__biz=MzI1MTIzMzI2MA==&mid=2650561380&idx=1&sn=f94b3eae23d0c6a975ae6dae1f0c1b68&chksm=f1feede7c68964f167ff9bc9be76bb348d551e64b9f57f0400a26cc397b238f9e90c06012b63&mpshare=1&scene=24&srcid=1017YBO9JrtAsGkBjW9oPd0Q#rd
AES–http://mp.weixin.qq.com/s?__biz=MzI1MTIzMzI2MA==&mid=2650561454&idx=1&sn=dd91cdd8f3853fe07e1f2d02f4f126a9&chksm=f1feed2dc689643bc143bc9462cc36315843a96e1babe372216375808148c43258278723749a&scene=0#rd