Java的加密算法

Java的加密算法Java的加密算法1. JDK提供的Base64编码操作Base64Util工具类测试方法:2. 消息摘要算法(MD5、SHA、HMAC)BytesToHex 工具类MessageDigestUtil 工具类测试方法:测试结果:3. 对称加密算法(DES、3DES、AES)DESUtil 工具类测试方法:测试结果:4. 非对称加密算法(DH、RSA)DHUtil 类测试方法:RSAUtil 工具类测试方法:测试截图:5. 数字签名算法(RSA、DSA)RSASignatureUtil 工具
摘要由CSDN通过智能技术生成

Java的加密算法

密码学算法分类

消息编码:Base64

消息摘要:MD类,SHA类,MAC

对称加密:DES,3DES,AES

非对称加密:RSA,DH密钥交换

数字签名:RSA signature,DSA signature

1. JDK提供的Base64编码操作

Base64Util工具类

package com.hzxy.test.utils;

import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
import java.io.IOException;

/*
* base64编码工具
* ye
* 2021.5.11
* */

public class Base64Util {
   
    public static String encrypt(byte[] data) {
   
        return new BASE64Encoder().encode(data);
    }

    public static String decrypt(String data) throws IOException {
   
        return new String(new BASE64Decoder().decodeBuffer(data));
    }

}

测试方法:

    @Test
    void testBase64Util() throws IOException {
   

        String data = "123456";

        String result = Base64Util.encrypt(data.getBytes());
        System.out.println(data +" 使用Base64编码的结果: " + result);

        String result2 = Base64Util.decrypt(result);
        System.out.println(result + "使用Base64解码的结果:" + result2);
    }

结果:
在这里插入图片描述

2. 消息摘要算法(MD5、SHA、HMAC)

消息摘要是对消息通过一个单向Hash算法进行计算,得到一个唯一的结果。每个消息对应一个唯一结果,所有结果的长度固定。应用于校验数据的完整性,防止在传输途中被篡改。

消息摘要主要有以下三个:

  • MD5(Message Digest)消息摘要算法
  • SHA(Secure Hash Algorithm)安全散列算法
  • MAC(Message Authentication Code)消息认证码算法,结合了MD5和SHA的优势,同时用密钥对摘要进行加密,是一种更为安全的消息摘要算法。

具体的使用:

BytesToHex 工具类

package com.hzxy.test.utils;


/*
* BytesToHex工具
* ye
* 2021.5.11
* */

public class BytesToHex {
   

    public static String fromBytesToHex(byte[] resultBytes) {
   
        StringBuilder builder = new StringBuilder();
        for (int i = 0; i < resultBytes.length; i++) {
   
            if (Integer.toHexString(0xFF & resultBytes[i]).length() == 1) {
   
                builder.append("0").append(
                        Integer.toHexString(0xFF & resultBytes[i]));
            } else {
   
                builder.append(Integer.toHexString(0xFF & resultBytes[i]));
            }
        }
        return builder.toString();
    }

}

MessageDigestUtil 工具类

package com.hzxy.test.utils;

import java.io.File;
import java.io.FileInputStream;
import java.security.DigestInputStream;
import java.security.MessageDigest;

import javax.crypto.KeyGenerator;
import javax.crypto.Mac;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;

/*
 * MessageDigestUtil工具
 * ye
 * 2021.5.11
 * */

public class MessageDigestUtil {
   

    /**
     * 计算MD5值
     */
    public static String encryptMD5(byte[] data) throws Exception {
   
        MessageDigest messageDigest = MessageDigest.getInstance("MD5");//MD5,MD2
        messageDigest.update(data);
        return BytesToHex.fromBytesToHex(messageDigest.digest());
    }

    /**
     * 计算文件的MD5值(指纹签名)
     */
    public static String getFileMD5(String path) throws Exception {
   
        FileInputStream fis = new FileInputStream(new File(path));
        DigestInputStream dis = new DigestInputStream(fis, MessageDigest.getInstance("MD5"));
        try {
   
            byte[] buffer = new byte[1024];
            int read = dis.read(buffer, 0, 1024);
            while (read != -1) {
   
                read = dis.read(buffer, 0, 1024);
            }
            MessageDigest md = dis.getMessageDigest();
            return BytesToHex.fromBytesToHex(md.digest());
        } finally {
   
            dis.close();
            fis.close();
        }

    }

    /**
     * 计算SHA值
     */
    public static String encryptSHA(byte[] data) throws Exception {
   
        MessageDigest messageDigest = MessageDigest.getInstance("SHA")
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值