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));
    }
}

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

相关推荐
魂梦翩跹如雨17 分钟前
数据库的“契约” —— 约束(Constrains)
java·数据库·mysql
white-persist34 分钟前
【vulhub shiro 漏洞复现】vulhub shiro CVE-2016-4437 Shiro反序列化漏洞复现详细分析解释
运维·服务器·网络·python·算法·安全·web安全
独自破碎E42 分钟前
面试官:你有用过Java的流式吗?比如说一个列表.stream这种,然后以流式去处理数据。
java·开发语言
2601_949818091 小时前
头歌答案--爬虫实战
java·前端·爬虫
FL16238631291 小时前
基于C#winform部署软前景分割DAViD算法的onnx模型实现前景分割
开发语言·算法·c#
2601_949817921 小时前
大厂Java进阶面试解析笔记文档
java·笔记·面试
郭wes代码1 小时前
大三Java课设:一行行敲出来的贪吃蛇,老师以为我是CV的
java·开发语言
baizhigangqw2 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶
算法·启发式算法·web app
IGAn CTOU2 小时前
王炸级更新!Spring Boot 3.4 正式发布,新特性真香!
java·spring boot·后端
C雨后彩虹2 小时前
最多等和不相交连续子序列
java·数据结构·算法·华为·面试