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加密》文章的全部内容了!
版权说明
文章采用: 《署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)》许可协议授权。版权声明:未标注转载均为本站原创,转载时请以链接形式注明文章出处。如有侵权、不妥之处,请联系站长删除。敬请谅解!