用户密码MD5和SHA加密

谢骏奇
2023-12-01

今天在项目中接触到了用户密码加密,在之前做一些简单的小项目根本没有考虑到数据库的安全性。其实在真正的项目中就得需要对用户密码加密。才真正了解了一下用户密码的加密。
用户密码的加密技术有很多,加密级别也有很多。我今天接触了MD5技术和SHA技术
MD5

md5的作用原理就是把你输入你用户密码转化成32位乱的数字和字符。并且它是一个不可逆的字符串变换算法换句话说就是,即使你看到源程序和算法描述,也无法将一个MD5的值变换回原始的字符串,从数学原理上说,是因为原始的字符串有无穷多个,这有点象不存在反函数的数学函数。
MD5 (tanajiya.tar.gz) = 0ca175b9c0f726a831d895e269332461

SHA的工作原理很像的。SHA 同样也是一个系列,它包括 SHA-1,SHA-224,SHA-256,SHA-384,和 SHA-512 等几种算法。其中,SHA-1,SHA-224 和 SHA-256 适用于长度不超过 2^64 二进制位的消息。SHA-384 和 SHA-512 适用于长度不超过 2^128 二进制位的消息。

package am.util;

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

/**
* 加密工具类
*
* md5加密出来的长度是32位
*
* sha加密出来的长度是40位
*
* @author am
*
*/
public class Encrypt {

/**
 * 加密
 * 
 * @param inputText
 * @return
 */
public static String e(String inputText) {
    return md5(inputText);
}

/**
 * 二次加密,应该破解不了了吧?
 * 
 * @param inputText
 * @return
 */
public static String md5AndSha(String inputText) {
    return sha(md5(inputText));
}

/**
 * md5加密
 * 
 * @param inputText
 * @return
 */
public static String md5(String inputText) {
    return encrypt(inputText, "md5");
}

/**
 * sha加密
 * 
 * @param inputText
 * @return
 */
public static String sha(String inputText) {
    return encrypt(inputText, "sha-1");
}

/**
 * md5或者sha-1加密
 * 
 * @param inputText
 *            要加密的内容
 * @param algorithmName
 *            加密算法名称:md5或者sha-1,不区分大小写
 * @return
 */
private static String encrypt(String inputText, String algorithmName) {
    if (inputText == null || "".equals(inputText.trim())) {
        throw new IllegalArgumentException("请输入要加密的内容");
    }
    if (algorithmName == null || "".equals(algorithmName.trim())) {
        algorithmName = "md5";
    }
    String encryptText = null;
    try {
        MessageDigest m = MessageDigest.getInstance(algorithmName);
        m.update(inputText.getBytes("UTF8"));
        byte s[] = m.digest();
        // m.digest(inputText.getBytes("UTF8"));
        return hex(s);
    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    }
    return encryptText;
}

/**
 * 返回十六进制字符串
 * 
 * @param arr
 * @return
 */
private static String hex(byte[] arr) {
    StringBuffer sb = new StringBuffer();
    for (int i = 0; i < arr.length; ++i) {
        sb.append(Integer.toHexString((arr[i] & 0xFF) | 0x100).substring(1, 3));
    }
    return sb.toString();
}

}

 类似资料: