加解密---消息摘要算法(未完待续)

1、概述

    消息摘要算法特征:加密过程不需要秘钥、加密后的数据无法被解密

2、消息摘要算法

    1.1  MD(Message Digest)

        MD家族(128位摘要信息)

        

复制代码
package com.exiuge.mytest;

import org.apache.commons.codec.binary.Hex;
import java.security.MessageDigest;

public class JdkMD5 {

    private static String src="hello,rose";

    public static void main(String[] args){
        enDeCode(src);
    }

    public static void enDeCode(String src){
        try {
            MessageDigest messageDigest=MessageDigest.getInstance("MD5");
            byte[] desBytes=messageDigest.digest(src.getBytes());
            System.out.println(Hex.encodeHexString(desBytes));
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}
复制代码
复制代码

package com.exiuge.mytest;

import org.bouncycastle.crypto.Digest;
import org.bouncycastle.crypto.digests.MD4Digest;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.util.encoders.Hex;
import java.security.MessageDigest;
import java.security.Security;

public class BouncyCastleMD4 {
private static String src="hello,rose";

public static void main(String[] args){
enDeCode(src);
}

public static void enDeCode(String src){
try {
//第一种方式
Digest digest =new MD4Digest();
digest.update(src.getBytes(),0,src.getBytes().length);
byte[] md4Bytes=new byte[digest.getDigestSize()];
digest.doFinal(md4Bytes,0);
System.out.println(Hex.toHexString(md4Bytes));

//第二种方式
Security.addProvider(new BouncyCastleProvider());
MessageDigest messageDigest=MessageDigest.getInstance("MD4");
byte[] md44Bytes=messageDigest.digest(src.getBytes());
System.out.println(Hex.toHexString(md44Bytes));
}catch (Exception e){
e.printStackTrace();
}
}
}
复制代码
复制代码
package com.exiuge.mytest;

import org.bouncycastle.crypto.Digest;
import org.bouncycastle.crypto.digests.MD5Digest;
import org.bouncycastle.util.encoders.Hex;

public class BouncyCastleMD5 {
    private static String src="hello,rose";

    public static void main(String[] args){
        enDeCode(src);
    }

    public static void enDeCode(String src){
        try {
            Digest digest =new MD5Digest();
            digest.update(src.getBytes(),0,src.getBytes().length);
            byte[] md5Bytes=new byte[digest.getDigestSize()];
            digest.doFinal(md5Bytes,0);
            System.out.println(Hex.toHexString(md5Bytes));
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}
复制代码
复制代码
package com.exiuge.mytest;

import org.apache.commons.codec.digest.DigestUtils;

public class CommonsCodecMD5 {

    private static String src="hello,rose";

    public static void main(String[] args){
        enDeCode(src);
    }

    public static void enDeCode(String src){
        System.out.println(DigestUtils.md5Hex(src.getBytes()));
    }
}
复制代码

      MD应用场景:

        注册

       

        登录

       

    1.2  SHA(Secure Hash Algorithm)

          SHA1、SHA2(SHA224、SHA256、SHA384、SHA512)

          

 

复制代码
package com.exiuge.mytest;

import org.apache.commons.codec.binary.Hex;
import java.security.MessageDigest;

public class JdkSHA1 {

    private static String src="hello,rose";

    public static void main(String[] args){
        enDeCode(src);
    }

    public static void enDeCode(String src){
        try {
            MessageDigest messageDigest=MessageDigest.getInstance("SHA");
            messageDigest.update(src.getBytes());
            System.out.println(Hex.encodeHexString(messageDigest.digest()));
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}
复制代码
复制代码
package com.exiuge.mytest;

import org.bouncycastle.crypto.Digest;
import org.bouncycastle.crypto.digests.SHA1Digest;
import org.bouncycastle.util.encoders.Hex;

public class BouncyCastleSHA1 {
    private static String src="hello,rose";

    public static void main(String[] args){
        enDeCode(src);
    }

    public static void enDeCode(String src){
        try {
            Digest digest=new SHA1Digest();
            digest.update(src.getBytes(),0,src.getBytes().length);
            byte[] sha1Bytes=new byte[digest.getDigestSize()];
            digest.doFinal(sha1Bytes,0);
            System.out.println(Hex.toHexString(sha1Bytes));
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}
复制代码
复制代码
package com.exiuge.mytest;

import org.apache.commons.codec.digest.DigestUtils;

public class CommonsCastleSHA1 {
    private static String src="hello,rose";

    public static void main(String[] args){
        enDeCode(src);
    }

    public static void enDeCode(String src){
        try {
            System.out.println(DigestUtils.sha1Hex(src));
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}
复制代码

      SHA应用场景:

      

    1.3  MAC(Message Authentication Code)

          融合MD、SHA;    

posted on   anpeiyong  阅读(505)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示