MD5Util.java import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;public class MD5Util{/** * * @param 待加密的字符串 * @return 32位加密后的字符串 */public static String encrypting(String psw){Strin
import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class MD5Util { /** * * @param 待加密的字符串 * @return 32位加密后的字符串 */ public static String encrypting(String psw) { String cipherString = ""; try { // 创建加密对象 MessageDigest md = MessageDigest.getInstance("MD5"); // 调用加密对象的方法,加密的动作已经完成 byte[] cipherBytes = md.digest(psw.getBytes()); for (byte b : cipherBytes) { // 第一步,将数据全部转换成正数: // 解释:为什么采用b&255 /* * b:它本来是一个byte类型的数据(1个字节) 255:是一个int类型的数据(4个字节) * byte类型的数据与int类型的数据进行运算,会自动类型提升为int类型 eg: b: 1001 1100(原始数据) * 运算时: b: 0000 0000 0000 0000 0000 0000 1001 1100 255: 0000 * 0000 0000 0000 0000 0000 1111 1111 结果:0000 0000 0000 0000 * 0000 0000 1001 1100 此时的temp是一个int类型的整数 */ int tmp = b & 255; // 第二步,将所有的数据转换成16进制的形式 // 注意:转换的时候注意if正数>=0&&<16,那么如果使用Integer.toHexString(),可能会造成缺少位数 // 因此,需要对temp进行判断 if (tmp >=0 && tmp < 16) { // 手动补上一个“0” cipherString = cipherString + "0" + Integer.toHexString(tmp); } else { cipherString = cipherString + Integer.toHexString(tmp); } } } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } return cipherString; } }