Java加密算法
2018-06-18 01:44:09来源:未知 阅读 ()
Java加密算法有三种:
1、单向加密算法
2、对错加密算法
3、非对称加密算法
单向加密算法
单向加密是不可逆的加密算法,加密的密文不能解密,常见的算法有MD5、SHA、HMAC。
MD5(信息摘要算法)
无论多长数据最后都编码成128位数据,同样数据一直一致。
用途:可用做文件校验、密码加密、散列数据。
代码:
public static String getMD5Str(String s) { try { MessageDigest md = MessageDigest.getInstance("MD5"); byte[] bytes = md.digest(s.getBytes("utf-8")); return toHex(bytes); } catch (Exception e) { throw new RuntimeException(e); } } public static String toHex(byte[] bytes) { final char[] HEX_DIGITS = "0123456789ABCDEF".toCharArray(); StringBuilder ret = new StringBuilder(bytes.length * 2); for (int i=0; i<bytes.length; i++) { ret.append(HEX_DIGITS[(bytes[i] >> 4) & 0x0f]); ret.append(HEX_DIGITS[bytes[i] & 0x0f]); } return ret.toString(); } public static void main(String[] args) { System.out.println(getMD5Str("123456")); //输出E10ADC3949BA59ABBE56E057F20F883E }
注意:
1、算出的字符串长度32,每个字符都是一个十六进制的数,一个十六进制的数转换成二进制是四位,也就是32长度的字符串换算成位32 * 4 = 128位。
2、算出的一定是32个字符的,16个是截取了结果一部分的。
3、MD5常配合base64编码用,但base64编码不是一种加密算法,只是一种数据编码。
SHA(安全散列算法)
安全性高于MD5,加密结果都是160位数据,用途与MD5类似。
SHA家族的五个算法,分别是SHA-1、SHA-224、SHA-256、SHA-384,和SHA-512,后四者有时并称为SHA-2。
HMAC(散列消息鉴别码)
用途:常用于对API参数进行请求校验。
对称加密算法
同一个密钥可加密,也可以解密,常见算法DES、AES、PBE。
DES(数据加密标准)
DES算法的入口参数有三个:Key、Data、Mode。其中Key为7个字节共56位,是DES算法的工作密钥;Data为8个字节64位,是要被加密或被解密的数据;Mode为DES的工作方式,有两种:加密或解密。
AES(DES的升级版)
PBE(基于口令加密)
非对称加密算法
需要两个密钥。公钥加密数据,私钥解密数据;私钥用来签名,公钥验证签名;常见算法RSA、DH。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇:面向对象编程
- 国外程序员整理的Java资源大全(全部是干货) 2020-06-12
- 2020年深圳中国平安各部门Java中级面试真题合集(附答案) 2020-06-11
- 2020年java就业前景 2020-06-11
- 04.Java基础语法 2020-06-11
- DES/3DES/AES 三种对称加密算法实现 2020-06-11
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash
