java MD5加密
package com.wiseweb.util; import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import sun.misc.BASE64Encoder; public class MD5 { public static String EncoderByMd5(String str) throws NoSuchAlgorithmException, UnsupportedEncodingException { // MD5 加密,BASE64解析成字符串 MessageDigest md5 = MessageDigest.getInstance("MD5"); BASE64Encoder base64en = new BASE64Encoder(); String newStr = base64en.encode(md5.digest(str.getBytes("utf-8"))); return newStr; } }
我这边就是直接创建一个类,单独的写一个md5加密的方法。
后面你在创建密码和获取密码的时候,直接调用这个方法就可以了。
例如:在注册方法的时候:::
uEntity.setPassword( MD5.EncoderByMd5(uEntity.getPassword()));
登陆的时候::::
user = userManager.checkUsername(uEntity.getName(), MD5.EncoderByMd5(uEntity.getPassword()));
第二种方法:
public static String EncoderByMd5(String sourceStr) { String result = ""; try { MessageDigest md = MessageDigest.getInstance("MD5"); md.update(sourceStr.getBytes()); byte b[] = md.digest(); int i; StringBuffer buf = new StringBuffer(""); for (int offset = 0; offset < b.length; offset++) { i = b[offset]; if (i < 0) i += 256; if (i < 16) buf.append("0"); buf.append(Integer.toHexString(i)); } result = buf.toString(); System.out.println("MD5(" + sourceStr + ",32) = " + result);
System.out.println("MD5(" + sourceStr + ",16) = " + buf.toString().substring(8, 24));
} catch (NoSuchAlgorithmException e) { System.out.println(e); } return result; }
第一种加密出来的结果是:A17SMRuW0qZexqb+cQRsFA==
第二种加密出来的结果是:32位: 23aa969097d27eab49da3604794cfaa8
16位: 89f9124819228947
看你想要那种结果。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。