java双向加密算法_Java加密算法

Java加密算法有三种:

1、单向加密算法

2、对错加密算法

3、非对称加密算法

单向加密算法

单向加密是不可逆的加密算法,加密的密文不能解密,常见的算法有MD5、SHA、HMAC。

MD5(信息摘要算法)

无论多长数据最后都编码成128位数据,同样数据一直一致。

用途:可用做文件校验、密码加密、散列数据。

代码:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

public staticString getMD5Str(String s) {try{

MessageDigest md= MessageDigest.getInstance("MD5");byte[] bytes = md.digest(s.getBytes("utf-8"));returntoHex(bytes);

}catch(Exception e) {throw newRuntimeException(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

ret.append(HEX_DIGITS[(bytes[i]>> 4) & 0x0f]);

ret.append(HEX_DIGITS[bytes[i]& 0x0f]);

}returnret.toString();

}public static voidmain(String[] args) {

System.out.println(getMD5Str("123456")); //输出E10ADC3949BA59ABBE56E057F20F883E

}

View Code

注意:

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。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值