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

Java函数库中常用的加密算法示例

发布时间:2023-06-25 00:37:44

Java函数库中有众多的加密算法可以使用,这些算法可以应用于不同的场合,例如保护数据传输,存储数据等。下面是几个常用的加密算法的示例:

一、MD5算法

MD5算法是一种常见的消息摘要算法,它可以将任意长度的消息压缩成一个128位的哈希值。使用Java的java.security.MessageDigest类可以实现MD5算法的加密和解密。

加密示例:

import java.security.MessageDigest;

public String getMD5(String str) {
    try {
        MessageDigest md = MessageDigest.getInstance("MD5");
        byte[] bytes = md.digest(str.getBytes("utf-8"));
        return toHexString(bytes);
    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
}

public String toHexString(byte[] bytes) {
    StringBuilder hexString = new StringBuilder();
    for (byte b : bytes) {
        String hex = Integer.toHexString(0xFF & b);
        if (hex.length() == 1)
            hexString.append('0');
        hexString.append(hex);
    }
    return hexString.toString();
}

解密示例:

由于MD5算法是不可逆的,所以MD5算法不能进行解密。

二、DES算法

DES算法是一种对称加密算法,它将原始数据对称地加密成一个密文,而且只有使用相同的密钥才能解密。Java的javax.crypto包中提供了DES算法的支持。

加密示例:

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
 
public String DESencrypt(String content, String password) {
    try {
        KeyGenerator kgen = KeyGenerator.getInstance("DES");
        kgen.init(56);
        SecretKey secretKey = kgen.generateKey();
        byte[] enCodeFormat = secretKey.getEncoded();
        SecretKeySpec key = new SecretKeySpec(enCodeFormat, "DES");
        Cipher cipher = Cipher.getInstance("DES");
        cipher.init(Cipher.ENCRYPT_MODE, key);
        byte[] byteContent = content.getBytes("utf-8");
        byte[] result = cipher.doFinal(byteContent);
        return Base64.getEncoder().encodeToString(result);
    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
}

解密示例:

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
 
public String DESdecrypt(String content, String password) {
    try {
        KeyGenerator kgen = KeyGenerator.getInstance("DES");
        kgen.init(56);
        SecretKey secretKey = kgen.generateKey();
        byte[] enCodeFormat = secretKey.getEncoded();
        SecretKeySpec key = new SecretKeySpec(enCodeFormat, "DES");
        Cipher cipher = Cipher.getInstance("DES");
        cipher.init(Cipher.DECRYPT_MODE, key);
        byte[] contentBytes = Base64.getDecoder().decode(content.getBytes("utf-8"));
        byte[] result = cipher.doFinal(contentBytes);
        return new String(result, "utf-8");
    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
}

三、AES算法

AES算法是一种对称加密算法,根据密钥长度不同,AES算法可以使用128位,192位和256位的密钥。Java的javax.crypto包中提供了AES算法的支持。

加密示例:

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
 
public String AESencrypt(String content, String password) {
    try {
        KeyGenerator kgen = KeyGenerator.getInstance("AES");
        kgen.init(128);
        SecretKey secretKey = kgen.generateKey();
        byte[] enCodeFormat = secretKey.getEncoded();
        SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES");
        Cipher cipher = Cipher.getInstance("AES");
        byte[] byteContent = content.getBytes("utf-8");
        cipher.init(Cipher.ENCRYPT_MODE, key);
        byte[] result = cipher.doFinal(byteContent);
        return Base64.getEncoder().encodeToString(result);
    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
}

解密示例:

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
 
public String AESdecrypt(String content, String password) {
    try {
        KeyGenerator kgen = KeyGenerator.getInstance("AES");
        kgen.init(128);
        SecretKey secretKey = kgen.generateKey();
        byte[] enCodeFormat = secretKey.getEncoded();
        SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES");
        Cipher cipher = Cipher.getInstance("AES");
        cipher.init(Cipher.DECRYPT_MODE, key);
        byte[] contentBytes = Base64.getDecoder().decode(content.getBytes("utf-8"));
        byte[] result = cipher.doFinal(contentBytes);
        return new String(result, "utf-8");
    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
}

总结

以上是Java函数库中常用的加密算法的示例,这些算法可以用于保护数据传输及存储等场合。需要注意的是,对于加密算法的选择越来越多,但是这也意味着一些加密算法的安全性也会不断被破解。因此,在应用这些加密算法时,需要根据自己的实际需要和要求,选择适当的加密算法,同时注意密钥的安全保管,以免出现安全隐患。