首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

快速简单的字符串在JAVA中加密/解密

在Java中,可以使用Java标准库中的加密和解密工具进行快速简单的字符串加密/解密。以下是一个简单的示例,使用Java标准库中的Cipher类进行AES加密/解密。

首先,需要导入以下依赖:

代码语言:java
复制
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;

然后,可以创建一个加密/解密的工具类:

代码语言:java
复制
public class AESUtil {

    private static final String ALGORITHM = "AES";
    private static final String TRANSFORMATION = "AES";

    public static String encrypt(String key, String data) throws Exception {
        SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), ALGORITHM);
        Cipher cipher = Cipher.getInstance(TRANSFORMATION);
        cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
        byte[] encryptedBytes = cipher.doFinal(data.getBytes());
        return Base64.getEncoder().encodeToString(encryptedBytes);
    }

    public static String decrypt(String key, String encryptedData) throws Exception {
        SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), ALGORITHM);
        Cipher cipher = Cipher.getInstance(TRANSFORMATION);
        cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
        byte[] decodedBytes = Base64.getDecoder().decode(encryptedData);
        byte[] decryptedBytes = cipher.doFinal(decodedBytes);
        return new String(decryptedBytes);
    }
}

接下来,可以使用该工具类进行加密/解密操作:

代码语言:java
复制
public static void main(String[] args) {
    String key = "1234567812345678"; // 密钥长度必须为16、24或32字节
    String data = "Hello, world!";

    try {
        String encryptedData = AESUtil.encrypt(key, data);
        System.out.println("Encrypted data: " + encryptedData);

        String decryptedData = AESUtil.decrypt(key, encryptedData);
        System.out.println("Decrypted data: " + decryptedData);
    } catch (Exception e) {
        e.printStackTrace();
    }
}

以上示例中,我们使用了AES加密算法,并使用了Java标准库中的Cipher类进行加密/解密操作。需要注意的是,加密和解密时使用的密钥必须相同,且密钥长度必须为16、24或32字节。

此外,还可以使用其他加密算法和工具类进行加密/解密操作,例如DES、RC4、RSA等算法,以及Java标准库中的其他加密工具类。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

RSA加密算法的java实现

实现基本上就是这样,都是大同小异。不过,问题来了,结下来才是重点。 **1. RSA加密算法对于加密数据的长度是有要求的。一般来说,明文长度小于等于密钥长度(Bytes)-11。解决这个问题需要对较长的明文进行分段加解密,这个上面的代码已经实现了。 2. 一旦涉及到双方开发,语言又不相同,不能够采用同一个工具的时候,切记要约定以下内容。 a)约定双方的BASE64编码 b)约定双方分段加解密的方式。我踩的坑也主要是这里,不仅仅是约定大家分段的大小,更重要的是分段加密后的拼装方式。doFinal方法加密完成后得到的仍然是byte[],因为最终呈现的是编码后的字符串,所以你可以分段加密,分段编码和分段加密,一次编码两种方式(上面的代码采用的是后一种,也推荐采用这一种)。相信我不是所有人的脑回路都一样的,尤其是当他采用的开发语言和你不通时。**

03
领券