MD5加密的简单应用

MD5用的是哈希函数,它的典型应用是对一段信息产生信息摘要,以防止被篡改。严格来说,MD5 不是一种加密算法而是摘要算法。无论是多长的输入,MD5 都会输出长度为 128bits 的一个串 (通常用 16 进制 表示为 32 个字符)。
下面是在SQLyog中使用MD5的简单语句:

UPDATE USER SET PASSWORD =MD5(‘0001’)WHERE id=1

结果如下:
注意记得加上where条件,否则全部密码都成为同一个值;

如果全都都需要MD5加密,则:

UPDATE USER SET PASSWORD =MD5(PASSWORD)

结果如下:
在这里插入图片描述
之前在JavaWeb练习的时候并没有给密码加密,如今密码加密过了,则需要在JavaWeb的练习中做些修改。
在做登录验证的时候,至少也是需要通过密码验证的,如今密码加过密了,不加改动,即使密码输入正确了登录的时候也是会出错。这时候就需要对密码进行加密;
首先建一个工具类,代码如下:

package com.vl.util;

import java.security.MessageDigest;

public class MD5Util {
	public final static String getMD5(String s) {
        char hexDigits[]={'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};       

        try {
            byte[] btInput = s.getBytes();
            // 获得 MD5 摘要算法的 MessageDigest 对象
            MessageDigest mdInst = MessageDigest.getInstance("MD5");
            // 使用指定的字节更新摘要
            mdInst.update(btInput);
            // 获得密文
            byte[] md = mdInst.digest();
            // 把密文转换成十六进制的字符串形式
            int j = md.length;
            char str[] = new char[j * 2];
            int k = 0;
            for (int i = 0; i < j; i++) {
                byte byte0 = md[i];
                str[k++] = hexDigits[byte0>>> 4 & 0xf];
                str[k++] = hexDigits[byte0 & 0xf];
            }
            return new String(str);
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

    public static void main(String[] args) {
        System.out.println(MD5Util.getMD5("admin"));
    }
}

创建好工具类之后,则需要引用工具类。在需要对密码进行解密的地方引用,如:

if (dbUser!=null) {		
					password=MD5Util.getMD5(password);
					if (dbUser.getPassword().equals(password)) {
						request.getSession().setAttribute("gUser", dbUser);	
						response.sendRedirect("UserServlet?fun=list");
					} else {
						request.setAttribute("error", "密码错误");
						request.getRequestDispatcher("/jsp/error.jsp").forward(request, response);
					}					
					
				} else {
					request.setAttribute("error", "该用户不存在");
					request.getRequestDispatcher("/jsp/error.jsp").forward(request, response);
				}	

password=MD5Util.getMD5(password);则是对密码进行解密的重要语句;
MD5在线解密破解的网站不在少数,那么MD5真的是被破解了吗?其实不是的。这些网站只是对加密算法进行反向查询,通过穷举字符组合的方式,创建明文密文对应查询数据库。部分密码可以查询出来,但是那些复杂的则比较困难。在中小型的项目中,MD5应该是够用了。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值