1.在几乎所有的项目中,都会有用户身份,既然有用户身份那就有登录操作,就会有用户信息,那就有用户的密码
2.我们如何实现用户的登录呢?
数据库中的 user 表里的 密码字段要给得足够长
然后我们不能直接把用户的密码明文地保存在数据库里,需要做加密
我们使用的加密手段:MD5 加密
MD5工具类
import org.springframework.util.StringUtils;
import java.security.MessageDigest;
/**
* Created by geely
*/
public class MD5Util {
private static String byteArrayToHexString(byte b[]) {
StringBuffer resultSb = new StringBuffer();
for (int i = 0; i < b.length; i++)
resultSb.append(byteToHexString(b[i]));
return resultSb.toString();
}
private static String byteToHexString(byte b) {
int n = b;
if (n < 0)
n += 256;
int d1 = n / 16;
int d2 = n % 16;
return hexDigits[d1] + hexDigits[d2];
}
/**
* 返回大写MD5
*
* @param origin
* @param charsetname
* @return
*/
private static String MD5Encode(String origin, String charsetname) {
String resultString = null;
try {
resultString = new String(origin);
MessageDigest md = MessageDigest.getInstance(\"MD5\");
if (charsetname == null || \"\".equals(charsetname))
resultString = byteArrayToHexString(md.digest(resultString.getBytes()));
else
resultString = byteArrayToHexString(md.digest(resultString.getBytes(charsetname)));
} catch (Exception exception) {
}
return resultString.toUpperCase();
}
public static String MD5EncodeUtf8(String origin) {
// origin = origin + PropertiesUtil.getProperty(\"password.salt\", \"\");
return MD5Encode(origin, \"utf-8\");
}
private static final String hexDigits[] = {\"0\", \"1\", \"2\", \"3\", \"4\", \"5\",
\"6\", \"7\", \"8\", \"9\", \"a\", \"b\", \"c\", \"d\", \"e\", \"f\"};
}
然后在用户登录和设置密码的操作里加上 MD5 加密
设置密码:
// MD5 加密
user.setPassword(MD5Util.MD5EncodeUtf8(user.getPassword()));
登录时,先把传过来的密码做MD5加密后再去数据库做验证:
String md5Password = MD5Util.MD5EncodeUtf8(password);
User user = userMapper.selectLogin(username,md5Password);
以上是《Java项目中用户密码的MD5加密》文章的全部内容,感谢您的支持!
以上就是《Java项目中用户密码的MD5加密》文章的全部内容了!