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

Java加密函数的使用方法及示例

发布时间:2023-09-27 06:04:50

Java提供了多种加密函数来实现数据的加密和解密操作。常用的加密函数主要包括对称加密和非对称加密。

1. 对称加密

对称加密算法是指使用相同的密钥进行加密和解密的算法,比如常用的AES和DES加密算法。使用对称加密算法进行加密和解密的步骤如下:

(1)创建Cipher对象:使用Cipher类的getInstance方法创建一个Cipher对象,同时传入加密算法的名称。

    Cipher cipher = Cipher.getInstance("AES");

(2)初始化Cipher对象:使用Cipher对象的init方法初始化Cipher对象,设置加密或解密模式以及密钥。

    cipher.init(Cipher.ENCRYPT_MODE, key);

(3)执行加密或解密操作:使用Cipher对象的doFinal方法执行加密或解密操作,传入需要加密或解密的数据。

    byte[] encryptedData = cipher.doFinal(data);

下面是一个使用AES加密算法进行数据加密和解密的示例代码:

import javax.crypto.Cipher;

import javax.crypto.KeyGenerator;

import javax.crypto.SecretKey;

import javax.crypto.spec.SecretKeySpec;

import java.util.Base64;

public class SymmetricEncryptionExample {

    public static void main(String[] args) throws Exception {

        String data = "Hello, World!";

        

        // 生成密钥

        KeyGenerator keyGenerator = KeyGenerator.getInstance("AES");

        keyGenerator.init(128);

        SecretKey secretKey = keyGenerator.generateKey();

        byte[] keyBytes = secretKey.getEncoded();

        SecretKeySpec keySpec = new SecretKeySpec(keyBytes, "AES");

        

        // 加密

        Cipher cipher = Cipher.getInstance("AES");

        cipher.init(Cipher.ENCRYPT_MODE, keySpec);

        byte[] encryptedData = cipher.doFinal(data.getBytes());

        String encryptedDataStr = Base64.getEncoder().encodeToString(encryptedData);

        System.out.println("Encrypted data: " + encryptedDataStr);

        

        // 解密

        cipher.init(Cipher.DECRYPT_MODE, keySpec);

        byte[] decryptedData = cipher.doFinal(Base64.getDecoder().decode(encryptedDataStr));

        String decryptedDataStr = new String(decryptedData);

        System.out.println("Decrypted data: " + decryptedDataStr);

    }

}

2. 非对称加密

非对称加密算法是指使用公钥和私钥进行加密和解密的算法,比如常用的RSA加密算法。使用非对称加密算法进行加密和解密的步骤如下:

(1)创建Cipher对象:使用Cipher类的getInstance方法创建一个Cipher对象,同时传入加密算法的名称。

    Cipher cipher = Cipher.getInstance("RSA");

(2)初始化Cipher对象:使用Cipher对象的init方法初始化Cipher对象,设置加密或解密模式以及密钥。

    cipher.init(Cipher.ENCRYPT_MODE, publicKey);

(3)执行加密或解密操作:使用Cipher对象的doFinal方法执行加密或解密操作,传入需要加密或解密的数据。

    byte[] encryptedData = cipher.doFinal(data);

下面是一个使用RSA非对称加密算法进行数据加密和解密的示例代码:

import javax.crypto.Cipher;

import java.security.KeyPair;

import java.security.KeyPairGenerator;

import java.security.PrivateKey;

import java.security.PublicKey;

import java.util.Base64;

public class AsymmetricEncryptionExample {

    public static void main(String[] args) throws Exception {

        String data = "Hello, World!";

        

        // 生成密钥对

        KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");

        keyPairGenerator.initialize(2048);

        KeyPair keyPair = keyPairGenerator.generateKeyPair();

        PublicKey publicKey = keyPair.getPublic();

        PrivateKey privateKey = keyPair.getPrivate();

        

        // 加密

        Cipher cipher = Cipher.getInstance("RSA");

        cipher.init(Cipher.ENCRYPT_MODE, publicKey);

        byte[] encryptedData = cipher.doFinal(data.getBytes());

        String encryptedDataStr = Base64.getEncoder().encodeToString(encryptedData);

        System.out.println("Encrypted data: " + encryptedDataStr);

        

        // 解密

        cipher.init(Cipher.DECRYPT_MODE, privateKey);

        byte[] decryptedData = cipher.doFinal(Base64.getDecoder().decode(encryptedDataStr));

        String decryptedDataStr = new String(decryptedData);

        System.out.println("Decrypted data: " + decryptedDataStr);

    }

}

以上就是Java加密函数的使用方法及示例。根据具体需求选择对称加密还是非对称加密算法,并根据算法的要求生成密钥,然后使用Cipher对象进行加密和解密操作即可。