MD5使用

本文介绍了MD5加密算法的基本概念及其在Java中的实现方法。MD5是一种单向函数算法,可以将任意大小的数据转化为固定长度的128位散列值,常用于文件校验和数据安全性验证。但由于其存在碰撞风险,现已较少应用于高安全要求场景。
MD5加密算法,即"Message-Digest Algorithm 5(信息-摘要算法)",它由MD2、MD3、MD4发展而来的一种单向函数算法(也就是HASH算法),它是国际著名的公钥加密算法标准RSA的第一设计者R.Rivest于上个世纪90年代初开发出来的。MD5的最大作用在于,将不同格式的大容量文件信息在用数字签名软件来签署私人密钥前"压缩"成一种保密的格式,关键之处在于——这种"压缩"是不可逆的。 Java JDK已经自带了MD5的实现,只要简单调用下就可以。
 
MD5,其实就是一中算法。可以将一个字符串,或文件,或压缩包,执行md5后,就可以生成一个固定长度为128bit的串。这个串,基本上是唯一的。
 
MD5较老,散列长度通常为128位,随着计算机运算能力提高,找到“碰撞”是可能的。因此,在安全要求高的场合不使用MD5。
 
java使用代码:
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class CreateMD5 {
    public static String getMd5(String plainTest){
        try{
            MessageDigest md = MessageDigest.getInstance("md5");
            byte[] input = plainTest.getBytes();
            md.update(input);
            byte[] b = md.digest();

            int i;

            StringBuffer sb = new StringBuffer();
            for(int k=0;k<b.length;k++){
                i=b[k];
                if(i<0){
                    i+=256;
                }
                if(i<16){
                    sb.append("0");
                }
                sb.append(Integer.toHexString(i));
            }
            //32位加密
            return sb.toString();
            //16位加密
            //return sb.toString().substring(8, 24);

        }catch(NoSuchAlgorithmException e){
            e.printStackTrace();
            return null;
        }
    }

    public static void main(String[] args){
        System.out.println(CreateMD5.getMd5("hello world"));
    }
}

 

转载于:https://www.cnblogs.com/xujiming/p/5578926.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值