涉及到的JAR包:
commons-codec-1.3.jar
/**
* 密码加密接口
*/
public interface PwdEncoder {
/**
* 密码加密
* @param rawPass 未加密密码,null作为空串
* @return 加密后密码
*/
public String encodePassword(String rawPass);
/**
* 密码加密
* @param rawPass 未加密密码,null作为空串
* @param salt 混淆码
* @return
*/
public String encodePassword(String rawPass, String salt);
/**
* 验证密码是否正确
* @param encPass 加密密码
* @param rawPass 未加密密码,null作为空串
* @return true:密码正确;false:密码错误
*/
public boolean isPasswordValid(String encPass, String rawPass);
/**
* 验证密码是否正确
* @param encPass 加密密码
* @param rawPass 未加密密码,null作为空串
* @param salt 混淆码
* @return true:密码正确;false:密码错误
*/
public boolean isPasswordValid(String encPass, String rawPass, String salt);
}
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import org.apache.commons.codec.binary.Hex;
/**
* MD5密码加密
*/
public class Md5PwdEncoder implements PwdEncoder {
/**
* 混淆码。防止破解。
*/
private String defaultSalt;
public String encodePassword(String rawPass) {
return encodePassword(rawPass, defaultSalt);
}
public String encodePassword(String rawPass, String salt) {
String saltedPass = mergePasswordAndSalt(rawPass, salt, false);
MessageDigest messageDigest = getMessageDigest();
byte[] digest;
try {
digest = messageDigest.digest(saltedPass.getBytes("UTF-8"));
} catch (UnsupportedEncodingException e) {
throw new IllegalStateException("UTF-8 not supported!");
}
return new String(Hex.encodeHex(digest));
}
public boolean isPasswordValid(String encPass, String rawPass) {
return isPasswordValid(encPass, rawPass, defaultSalt);
}
public boolean isPasswordValid(String encPass, String rawPass, String salt) {
if (encPass == null) {
return false;
}
String pass2 = encodePassword(rawPass, salt);
return encPass.equals(pass2);
}
protected final MessageDigest getMessageDigest() {
String algorithm = "MD5";
try {
return MessageDigest.getInstance(algorithm);
} catch (NoSuchAlgorithmException e) {
throw new IllegalArgumentException("No such algorithm [" + algorithm + "]");
}
}
/**
* 将密码和混淆码拼接类
* @param password 密码
* @param salt 混淆码
* @param strict 是否需要检查混淆码中包含<b>{</b> or <b>}</b>
* @return
*/
protected String mergePasswordAndSalt(String password, Object salt, boolean strict) {
if (password == null) {
password = "";
}
if (strict && (salt != null)) {
if ((salt.toString().lastIndexOf("{") != -1) || (salt.toString().lastIndexOf("}") != -1)) {
throw new IllegalArgumentException("Cannot use { or } in salt.toString()");
}
}
if ((salt == null) || "".equals(salt)) {
return password;
} else {
return password + "{" + salt.toString() + "}";
}
}
/**
* 获得混淆码
* @return
*/
public String getDefaultSalt() {
return defaultSalt;
}
/**
* 设置混淆码
* @param salt
*/
public void setSefaultSalt(String defaultSalt) {
this.defaultSalt = defaultSalt;
}
public static void main(String[] args){
Md5PwdEncoder md5PwdEncoder = new Md5PwdEncoder();
System.out.println(md5PwdEncoder.encodePassword("ggggg", "ssss"));
}
}
分享到:
相关推荐
JavaScript中的MD5加密工具类是用于对数据进行安全哈希的一种方法,广泛应用于密码存储、数据完整性校验等场景。MD5(Message-Digest Algorithm 5)是一种广泛使用的哈希函数,它能将任意长度的输入转化为固定长度的...
Java Md5加密工具类
js的md5加密工具类
md5加密工具类
### Java_MD5加密工具类详解 #### 一、概述 在信息安全领域,数据加密是确保数据安全的重要手段之一。MD5(Message-Digest Algorithm 5)作为一种常用的散列算法,在许多场景下被用来生成固定长度的摘要信息。本文...
以下是一个简单的Java MD5加密工具类示例: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class MD5Util { private static final String MD5 = "MD5"; ...
我们的Java MD5加密工具类以String... inputStrs为武器,打破了传统加密函数的单值局限。这意味着,无论是单独的密码字符串,还是需要合并加密的多部分数据,只需一个方法调用,一切尽在掌握。这不仅大幅提升了编码...