MD5加密

MD5加密,第1张

1.MD5加密的定义
  • MD5的全称是Message-Digest Algorithm 5。MD5加密算法是一种单向加密的手段,属于计算机安全领域中的散列加密,使用的是Hash算法。
  • MD5加密之后是一个字符串,是一个定长的32位的字符串。MD5先将原来的数据变成一个16个字节的数组,然后将这个长度为16的字节数组用16进制表示,这个16进制的字符串就是加密最后的结果。
2.MD5加密的特点
  • MD5加密之后的字符串是定长的,长度是32。
  • MD5加密是单向加密,不可逆(从结果无法反推原始数据)。
  • MD5抗碰撞性,即两个明文不同的字符串MD5加密之后几乎不可能相同。
3.MD5的应用场景
  • 用户密码保护:将数据库密码加密之后存入数据库中,在以后登录的时候,将输入的密码进行MD5加密,然后再讲加密后的字符串和数据库中的进行比较。
  • 文件完整性校验:先在发送端计算一次文件的MD5值,然后接收端接收到数据之后,再计算一次MD5值,然后比较两次的MD5值,如果一样,文件就是完整的。
  • 云盘秒传:云盘上传时计算MD5,并在自己的数据库中搜索一下 MD5是否存在,存在则使用已有的文件就可以了,从而实现云盘秒传。
  • 数字发布:程序发布时,发布其MD5值,下载之后,计算一个MD5值,比较这两个MD5值是否相同,通过这种方式可以知道程序是否被篡改。
4.MD5的代码实现
	public class MD5 {
	    /**
	     * MD5加密算法的调用
	     * @param string 明文
	     * @return 返回加密后的密文
	     */
	    public static String md5Encrypt(String string) throws NoSuchAlgorithmException {
	        byte[] bytes = string.getBytes(StandardCharsets.UTF_8);
	        MessageDigest digest = MessageDigest.getInstance("md5");
	        byte[] result = digest.digest(bytes);
	        //对于加密后的结果进行输出:将字节数组转为16进制的字符串
	        StringBuffer sb = new StringBuffer();
	        for (byte b : result) {
	            int num = b & 0xff;//加盐,转类型的时候保证补码相同
	            String str = Integer.toHexString(num);
	            if(str.length() == 1){
	                sb.append("0");
	            }
	            sb.append(str);
	        }
	        return sb.toString();
	    }
	
	    public static void main(String[] args) throws NoSuchAlgorithmException {
	        String text = "123456";
	        String md5Encrypt = md5Encrypt(text);
	        //123456使用MD5加密之后的值是e10adc3949ba59abbe56e057f20f883e
	        System.out.println("e10adc3949ba59abbe56e057f20f883e".equals(md5Encrypt));
	        System.out.println(text + "MD5加密之后的值是:" + md5Encrypt);
	    }
	}

参考:https://blog.csdn.net/m0_46582525/article/details/123757932

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/727330.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-26
下一篇 2022-04-26

发表评论

登录后才能评论

评论列表(0条)

保存