java使用RSA加密方式实现数据加密解密

全栈工程师开发手册 (作者:栾鹏)
java教程全解

java使用RSA加密方式实现数据加密解密,需要首先产生私钥和公钥

测试代码

public static void main(String args[]) 
{
	try {
		RSADemo rsa=new RSADemo();
		rsa.generateKey();
		byte[] data=rsa.encrypt("luanpeng".getBytes());
		byte[] data1=rsa.decrypt(data);
		String str=new String(data1);
		System.out.println(str);
	} catch (Exception e) {
		System.out.println(e.toString());
	}
}

RSA工具类的实现

package com.lp.app.safe;

import java.security.*;
import java.security.interfaces.*;
import java.math.*;

public class RSADemo {
	public RSADemo() {
	}
	PublicKey pbkey;
	PrivateKey prkey;
	public void generateKey() {
		try {
			KeyPairGenerator kpg = KeyPairGenerator.getInstance("RSA");
			kpg.initialize(1024);
			KeyPair kp = kpg.genKeyPair();
			pbkey = kp.getPublic();
			prkey = kp.getPrivate();
		} catch (Exception e) {
		}
	}

	//加密,需要公钥
	public byte[] encrypt(byte[] ptext) throws Exception {
		// 获取公钥及参数e,n
		RSAPublicKey pbk = (RSAPublicKey)pbkey;
		BigInteger e = pbk.getPublicExponent();
		BigInteger n = pbk.getModulus();
		// 获取明文m
		BigInteger m = new BigInteger(ptext);
		// 计算密文c
		BigInteger c = m.modPow(e, n);
		return c.toByteArray();
	}

	//使用私钥进行解密
	public byte[] decrypt(byte[] ctext) throws Exception {
		// 读取密文
		BigInteger c = new BigInteger(ctext);
		// 读取私钥
		RSAPrivateKey prk = (RSAPrivateKey)prkey;
		BigInteger d = prk.getPrivateExponent();

		// 获取私钥参数及解密
		BigInteger n = prk.getModulus();
		BigInteger m = c.modPow(d, n);

		// 显示解密结果
		byte[] mt = m.toByteArray();
		return mt;
	}

}
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

腾讯AI架构师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值