从公司的系统单点登录至第三方系统,需要将第三方提供的请求报文发送过去,需要按照第三方文档规定进行请求:
其中有一字段需要加密后发送过去,并且要求采用MD5 32位加密:
MD5 32位加密方式:
public String getMD5(String str) {
try {
// 生成一个MD5加密计算摘要
MessageDigest md = MessageDigest.getInstance("MD5");
// 计算md5函数
md.update(str.getBytes("utf-8"));
// digest()最后确定返回md5 hash值,返回值为8为字符串。因为md5 hash值是16位的hex值,实际上就是8位的字符
// BigInteger函数则将8位的字符串转换成16位hex值,用字符串来表示;得到字符串形式的hash值
String md5=new BigInteger(1, md.digest()).toString(16);
//BigInteger会把0省略掉,需补全至32位
return md5.length()==32?md5:getMD5("0" + md5);
} catch (Exception e) {
throw new RuntimeException("MD5加密错误:" + e.getMessage(), e);
}
}
此时需要看清楚采用什么编码格式加密,要确定第三方采用的是什么编码格式,这里和第三方设置的编码格式相同。