欢迎访问宙启技术站
智能推送

如何在Java中实现简单的加密函数

发布时间:2023-07-02 07:54:24

在Java中实现简单的加密函数可以使用一些常见的加密算法,比如MD5、SHA-1、AES等。以下是使用MD5算法进行加密的示例代码:

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

public class SimpleEncryption {

    public static String encrypt(String input) throws NoSuchAlgorithmException {
        // 创建MessageDigest对象,选择MD5算法
        MessageDigest md = MessageDigest.getInstance("MD5");
        // 将输入的字符串转化为字节数组
        byte[] inputBytes = input.getBytes();
        // 对字节数组进行加密
        byte[] encryptedBytes = md.digest(inputBytes);
        
        // 将加密后的字节数组转化为字符串
        StringBuilder sb = new StringBuilder();
        for (byte b : encryptedBytes) {
            sb.append(String.format("%02x", b));
        }
        
        return sb.toString();
    }

    public static void main(String[] args) {
        try {
            System.out.println(encrypt("hello")); // 输出加密后的字符串
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
    }
}

运行结果为:

5d41402abc4b2a76b9719d911017c592

上述代码中使用了MessageDigest类提供的digest(byte[] input)方法对字节数组进行加密,然后使用StringBuilder将加密后的字节数组转化为字符串。String.format("%02x", b)可将字节b转换为两位的十六进制数。最后通过调用toString()方法返回加密后的字符串。

通过使用不同的加密算法,可以实现更高级的数据加密。例如使用AES算法对称加密字符串,可以使用Java加密扩展(JCE)提供的Cipher类。以下是使用AES算法进行加密的示例代码:

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.security.NoSuchAlgorithmException;


public class SimpleEncryption {

    public static String encrypt(String input) throws Exception {
        // 生成AES密钥
        KeyGenerator keyGenerator = KeyGenerator.getInstance("AES");
        keyGenerator.init(128);
        SecretKey secretKey = keyGenerator.generateKey();
        byte[] secretKeyBytes = secretKey.getEncoded();

        // 将密钥保存为字节数组
        SecretKeySpec secretKeySpec = new SecretKeySpec(secretKeyBytes, "AES");

        // 创建Cipher对象,选择AES算法
        Cipher cipher = Cipher.getInstance("AES");
        cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);

        // 将输入的字符串转化为字节数组
        byte[] inputBytes = input.getBytes();

        // 对字节数组进行加密
        byte[] encryptedBytes = cipher.doFinal(inputBytes);

        // 将加密后的字节数组转化为字符串
        StringBuilder sb = new StringBuilder();
        for (byte b : encryptedBytes) {
            sb.append(String.format("%02x", b));
        }

        return sb.toString();
    }

    public static void main(String[] args) {
        try {
            System.out.println(encrypt("hello")); // 输出加密后的字符串
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

运行结果将会是一个经过AES算法加密后的字符串。

以上是两种在Java中实现简单的加密函数的示例代码,你可以根据需要选择合适的加密算法以及密钥长度。