md5加密,jdk7 与jdk8对含有中文的明文加密注意
2015-12-29 12:27
627 查看
private static final String ALGORITHM_MD5 = "MD5";
/**
* Encrypt the password with MD5
*
* @param pass
* the password to encryption
* @return encryption string
*/
public static String getPassMD5(String pass) {
String keys = null;
try {
MessageDigest md = MessageDigest.getInstance(ALGO 4000 RITHM_MD5);
if (pass == null) {
pass = "";
}
byte[] bPass = pass.getBytes("UTF-8");
// byte[] bPass = pass.getBytes(); j7 默认编码是u8 而j8不是,所以这个时候,中文加密有问题,j7与j8加密出来的密文不想等,J7是对的
System.out.println(Arrays.toString(bPass));
md.update(bPass);
// keys = new String(md.digest(), "GBK");
keys = bytesToHexString(md.digest());
} catch (Exception aex) {
aex.printStackTrace();
}
return keys;
}
/**
* 将beye[]转换为十六进制字符串
*
* @param bArray
* @return
*/
public static final String bytesToHexString(byte[] bArray) {
System.out.println(Arrays.toString(bArray));
StringBuffer sb = new StringBuffer(bArray.length);
String sTemp;
for (int i = 0; i < bArray.length; i++) {
sTemp = Integer.toHexString(0xFF & bArray[i]);
if (sTemp.length() < 2) {
sb.append(0);
}
sb.append(sTemp.toUpperCase());
}
return sb.toString().toLowerCase();
} 阅读更多
/**
* Encrypt the password with MD5
*
* @param pass
* the password to encryption
* @return encryption string
*/
public static String getPassMD5(String pass) {
String keys = null;
try {
MessageDigest md = MessageDigest.getInstance(ALGO 4000 RITHM_MD5);
if (pass == null) {
pass = "";
}
byte[] bPass = pass.getBytes("UTF-8");
// byte[] bPass = pass.getBytes(); j7 默认编码是u8 而j8不是,所以这个时候,中文加密有问题,j7与j8加密出来的密文不想等,J7是对的
System.out.println(Arrays.toString(bPass));
md.update(bPass);
// keys = new String(md.digest(), "GBK");
keys = bytesToHexString(md.digest());
} catch (Exception aex) {
aex.printStackTrace();
}
return keys;
}
/**
* 将beye[]转换为十六进制字符串
*
* @param bArray
* @return
*/
public static final String bytesToHexString(byte[] bArray) {
System.out.println(Arrays.toString(bArray));
StringBuffer sb = new StringBuffer(bArray.length);
String sTemp;
for (int i = 0; i < bArray.length; i++) {
sTemp = Integer.toHexString(0xFF & bArray[i]);
if (sTemp.length() < 2) {
sb.append(0);
}
sb.append(sTemp.toUpperCase());
}
return sb.toString().toLowerCase();
} 阅读更多
相关文章推荐
- 使用crypto模块实现md5加密功能(解决中文加密前后端不一致的问题)
- 对中文进行MD5加密的注意事项(Java版)
- SHA1 加密 你不知道的事 针对含有中文编码加密处理
- Wrap加密一些注意点(中文汉字加密的问题)
- Java: md5 加密中文 & 注意编码
- JAVA利用RSA加密算法的长度限制问题解决方案注意: RSA加密明文最大长度117字节,解密要求密文最大长度为128字节,所以在加密和解密的过程中需要分块进行。 RSA加密对明文的长度是有限制的,如
- Java对用户密码进行MD5加密、十六进制加密 -- 基于jdk
- Win7系统上利用Texlive2015写含有中文文档应该注意的问题
- Asp.Net C#中除了MD5加密之外还经常用到了AES加密、解密与DES加密、解密,本次先介绍DES的加密及解密。注意的是DES的密匙是8位的。
- js进行MD5加密(含中文),与后台JAVA加密之后结果不同(解决)
- [读书笔记]C# DES 加密/解密类库,支持文件和中文/UNICODE字符,返回BASE64编码字符串
- 中文转换为日文的几点注意事项
- 【javaweb:servlet】从服务端下载中文名称文件应该注意的问题!!!
- JS实现的base64加密、md5加密及sha1加密详解
- jQuery选择器中含有空格的注意事项
- 对称加密DES-jdk实现和bc实现
- Java中常用的加密方法(JDK)
- win10安装jdk7环境变量注意事项
- ASP.NET2.0:页面中链入的CSS、js文件带中文时需注意
- Redhat Linux配置JDK和Tomcat需要注意的地方