Java密码学之加解密

前篇:Java密码学之数字签名_东皋长歌的博客-CSDN博客

日常开发中用的比较多的功能点,加解密数据,用Java实现也是很快很实用。

下面记录一下加解密数据的过程。

1,创建密钥对生成器

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

2,初始化密钥

keyPairGen.initialize(2048);

3,生成密钥对

KeyPair pair = keyPairGen.generateKeyPair();

4,创建加密对象

Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");

5,用公钥初始化加密对象

cipher.init(Cipher.ENCRYPT_MODE, publicKey);

6,添加待加密内容到加密对象

byte[] input = "Welcome to Shenzhen".getBytes();

cipher.update(input);

7,使用公钥加密内容

byte[] cipherText = cipher.doFinal();

System.out.println( "加密后的内容:"+new String(cipherText, "UTF8"));

8,用私钥初始化加密对象,使用DECRYPT_MODE

cipher.init(Cipher.DECRYPT_MODE, pair.getPrivate());

9,解密密文

byte[] decipheredText = cipher.doFinal(cipherText);

System.out.println("解密后的内容:"+new String(decipheredText));

10,完整过程
java 复制代码
import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.NoSuchPaddingException;
import java.io.UnsupportedEncodingException;
import java.security.*;

public class CipherDemo {
    public static void main(String[] args) throws NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException, IllegalBlockSizeException, BadPaddingException, UnsupportedEncodingException {
        //创建密钥对生成器,后面算法选择有: DiffieHellman,DSA,RSA 三种,如果是其他的话,就会抛出异常NoSuchAlgorithmException
        KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("RSA");

        //初始化密钥生成器,一般长度要大于待加密内容
        keyPairGen.initialize(2048);

        //生成密钥对
        KeyPair pair = keyPairGen.generateKeyPair();

        //获取公钥
        PublicKey publicKey = pair.getPublic();

        //创建加密对象,后面内容为填充算法,RSA/ECB/PKCS1Padding,RSA/ECB,RSA//PKCS1Padding,RSA 4种选择,如果不在这里面会抛出异常NoSuchAlgorithmException,NoSuchPaddingException
        Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");

        //用公钥初始化加密对象,模式有ENCRYPT_MODE,DECRYPT_MODE,WRAP_MODE,UNWRAP_MODE 4种模式
        cipher.init(Cipher.ENCRYPT_MODE, publicKey);

        //添加待加密内容到加密对象
        byte[] input = "Welcome to Shenzhen".getBytes();
        cipher.update(input);

        //使用公钥加密内容
        byte[] cipherText = cipher.doFinal();
        System.out.println( "加密后的内容:"+new String(cipherText, "UTF8"));

        //用私钥初始化加密对象,使用DECRYPT_MODE
        cipher.init(Cipher.DECRYPT_MODE, pair.getPrivate());

        //解密密文
        byte[] decipheredText = cipher.doFinal(cipherText);
        System.out.println("解密后的内容:"+new String(decipheredText));
    }
}

注意要结合自己项目里实际场景使用

相关推荐
身如柳絮随风扬18 小时前
Java中的CAS机制详解
java·开发语言
-dzk-19 小时前
【代码随想录】LC 59.螺旋矩阵 II
c++·线性代数·算法·矩阵·模拟
风筝在晴天搁浅20 小时前
hot100 78.子集
java·算法
Jasmine_llq20 小时前
《P4587 [FJOI2016] 神秘数》
算法·倍增思想·稀疏表(st 表)·前缀和数组(解决静态区间和查询·st表核心实现高效预处理和查询·预处理优化(提前计算所需信息·快速io提升大规模数据读写效率
超级大只老咪20 小时前
快速进制转换
笔记·算法
m0_7066532320 小时前
C++编译期数组操作
开发语言·c++·算法
故事和你9120 小时前
sdut-Java面向对象-06 继承和多态、抽象类和接口(函数题:10-18题)
java·开发语言·算法·面向对象·基础语法·继承和多态·抽象类和接口
qq_4232339021 小时前
C++与Python混合编程实战
开发语言·c++·算法
TracyCoder12321 小时前
LeetCode Hot100(19/100)——206. 反转链表
算法·leetcode
m0_7155753421 小时前
分布式任务调度系统
开发语言·c++·算法