package com.client.rsa;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.math.BigInteger;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.NoSuchAlgorithmException;
import java.security.interfaces.RSAPrivateCrtKey;
import java.security.interfaces.RSAPublicKey;
import com.nettyServer.util.BaseString;
import com.nettyServer.util.ByteUtils;
public class RSAUtil {
public String[] initGenKey(int keylen) {
String[] genInfo = new String[5];
try {
KeyPairGenerator kpg = KeyPairGenerator.getInstance("RSA");
kpg.initialize(keylen);
KeyPair kp = kpg.generateKeyPair();
RSAPublicKey puk = (RSAPublicKey) kp.getPublic();
RSAPrivateCrtKey prk = (RSAPrivateCrtKey) kp.getPrivate();
BigInteger e = puk.getPublicExponent();
BigInteger n = puk.getModulus();
log("n len(" + n.toByteArray().length + ")");
BigInteger d = prk.getPrivateExponent();
BigInteger p = prk.getPrimeP();
BigInteger q = prk.getPrimeQ();
genInfo[0] = e.toString();
genInfo[1] = n.toString();
genInfo[2] = d.toString();
genInfo[3] = p.toString();
genInfo[4] = q.toString();
String[] des = { "e", "n", "d", "p", "q" };
for (int i = 0; i < genInfo.length; i++) {
log(des[i] + "=" + genInfo[i]);
}
} catch (NoSuchAlgorithmException ex) {
ex.printStackTrace();
}
return genInfo;
}
//encrypt data
public byte[] encrypt(byte[] ptext, String eStr, String nStr) throws IOException {
log("*******************************encrypt start*************************************");
BigInteger e = new BigInteger(eStr);//publickey param d
BigInteger n = new BigInteger(nStr);//publickey param d
int len = (n.toByteArray().length - 1), i = 0;
int inputLen = ptext.length;
BigInteger m = null;
BigInteger c = null;
ByteArrayOutputStream out = new ByteArrayOutputStream();
int offSet = 0;
byte[] cache=null;
while (inputLen - offSet > 0) {
if (inputLen - offSet > len) {
cache = new byte[len];
} else {
cache = new byte[inputLen - offSet];
}
System.arraycopy(ptext, offSet, cache, 0, cache.length);
m = new BigInteger(cache);
c = m.modPow(e, n);
out.write(c.toByteArray());
log("encrypt before:len(" + cache.length + "),data("+i+"):"
+ ByteUtils.bytesToHexString(cache));
log("encrypt after data("+i+"):"
+ ByteUtils.bytesToHexString(c.toByteArray()));
i++;
offSet = i * len;
}
byte[] encryptData=out.toByteArray();
out.close();
log("*******************************encrypt end*************************************");
return encryptData;
}
//decrypt data
public byte[] decrypt(byte[] miwen, String dStr, String nStr) throws IOException {
log("*******************************decrypt start*************************************");
BigInteger d = new BigInteger(dStr);//privatekey param d
BigInteger n = new BigInteger(nStr);//privatekey param n
BigInteger c = null;
BigInteger m = null;
int len = n.toByteArray().length;
int i = 0;
ByteArrayOutputStream out = new ByteArrayOutputStream();
int inputLen = miwen.length;
int offSet = 0;
byte[] cache = null;
while (inputLen - offSet > 0) {
if (inputLen - offSet > len) {
cache = new byte[len];
} else {
cache = new byte[inputLen - offSet];
}
System.arraycopy(miwen, offSet, cache, 0, cache.length);
c = new BigInteger(cache);
m = c.modPow(d, n);
byte[] dData = m.toByteArray();
out.write(dData);
log("decrypt before data("+i+"):"
+ ByteUtils.bytesToHexString(cache));
log("decrypt after:len(" + dData.length + "),data("+i+"):"
+ ByteUtils.bytesToHexString(dData));
i++;
offSet = i * len;
}
byte[] entryDataB=out.toByteArray();
out.close();
log("*******************************decrypt end*************************************");
return entryDataB;
}
private void log(String log){
System.out.println(log);
}
public static void main(String[] args) throws IOException {
RSAUtil rsaUtil = new RSAUtil();
String[] p = rsaUtil.initGenKey(1023);// 1023
//中文需要采用base编码后再加密
String data = "18BB49FBC8AE1A82EECFECF8BB89C9D35FAAB857CC0C3B959DA3C3D513CAB255A0B627FDDE15813629A00FBF464740A32C7907B5B845245D9CDAC3F5F68A666EAFDE3FCE21A8096A61BABB659DDDB899F8CD29B2604199BC1F42993DFAB09ABFBE6BE69B7C299CBA6797EEE21665AF6B67A8061DBE6FA2EB0825C366DD812129";
//String text = Base64.encodeBase64String(data.getBytes("GBK"));
rsaUtil.log("(" + data.length() + ")" + data);
ByteArrayOutputStream out = new ByteArrayOutputStream();
out.write(BaseString.getBytes(data));
byte[] minwen = out.toByteArray();
out.close();
byte[] hex = rsaUtil.encrypt(minwen, p[0], p[1]);
byte[] decodeData = rsaUtil.decrypt(hex, p[2], p[1]);
data = BaseString.byteToString(decodeData);
//data = BaseString.byteToString(Base64.decodeBase64(decodeData));
rsaUtil.log("(" + data.length() + ")" + data);
}
}
output:
n len(128)
e=65537
n=79878443116477431723910720076331964206927196983187460111829662096543709950682705577119366644900259032296548146226108881718640174009506648698055329399979826968504236032315385550029317396676828095359442971095598662249798287465446643154424521383364489258800969007909367639398542203155486245540834166630656463551
d=26360849103913421324209851744982341606534040562619259155876099483101871596401506877366032345024990499267737969491711291237175178654464040130636749687394346556715475310635822940069011833047004651164959543795626563240523875100964945568109834945618143409494207572709757223766144562392543175635168401408831807649
p=12388121363302700405059571893776373129179128456352582548743075852274073073044285422961339481772197365397373993998587373598128718142470712954759279729185579
q=6447986807192665658869257921655147348637730988762875266579286105565709187930397704433502779690215309166895026920782468729159257017248953918267942262113469
(256)18BB49FBC8AE1A82EECFECF8BB89C9D35FAAB857CC0C3B959DA3C3D513CAB255A0B627FDDE15813629A00FBF464740A32C7907B5B845245D9CDAC3F5F68A666EAFDE3FCE21A8096A61BABB659DDDB899F8CD29B2604199BC1F42993DFAB09ABFBE6BE69B7C299CBA6797EEE21665AF6B67A8061DBE6FA2EB0825C366DD812129
*******************************encrypt start*************************************
encrypt before:len(127),data(0):31384242343946424338414531413832454543464543463842423839433944333546414142383537434330433342393539444133433344353133434142323535413042363237464444453135383133363239413030464246343634373430413332433739303742354238343532343544394344414333463546363841363636
encrypt after data(0):0A393732881F8FD5347AC6EA5DD17D862567608038C39FDB57E0E0FCFA6C6BD2795FE9A7B52C9D60B57B70E867C692B907140A784C1C86E61E00E4CCBBC4541A83C97F7478C0F0A662066755A390022EB76ADA8948893564DF56524C58E47ACC672624C0EB9CE6822B703F69D851F9D68C84FB75D0A6636DE14E3A995AB38D3C
encrypt before:len(127),data(1):45414644453346434532314138303936413631424142423635394444444238393946384344323942323630343139394243314634323939334446414230394142464245364245363942374332393943424136373937454545323136363541463642363741383036314442453646413245423038323543333636444438313231
encrypt after data(1):48845A09A4FF5B012BBE42FC83F250B0AEA5D4FE1EA6A59BE813166C561EB1BA4F1744E79F50FC072016FF68384DCA1CA86B90BE50753956B9F1D5B68983F67C63EAF8ECFD62F1A6C3491469F6E6CFD8E895694678B2A24A9098FA120EF826C461B0ABF8B1B0C9E4EFD8E70547553068BA8560B61F7691E435E947E999A4B5C0
encrypt before:len(2),data(2):3239
encrypt after data(2):3D940F0A14DA5A9838AAF70049C978529569667BB5D3191A7075A3DA53205EA2C74E4F3CF21814514A45275246CBB579F9768ED321BFEAA8CCED6C6EA683DD866CB5660B513360799D69C4CF6BEBDCD0A1976510A6C6FF19E6A4915B85A5533FE5644E4CD761B0A37F3D19004685C52C8A931F074DE15D615DA88C3E98D99FD4
*******************************encrypt end*************************************
*******************************decrypt start*************************************
decrypt before data(0):0A393732881F8FD5347AC6EA5DD17D862567608038C39FDB57E0E0FCFA6C6BD2795FE9A7B52C9D60B57B70E867C692B907140A784C1C86E61E00E4CCBBC4541A83C97F7478C0F0A662066755A390022EB76ADA8948893564DF56524C58E47ACC672624C0EB9CE6822B703F69D851F9D68C84FB75D0A6636DE14E3A995AB38D3C
decrypt after:len(127),data(0):31384242343946424338414531413832454543464543463842423839433944333546414142383537434330433342393539444133433344353133434142323535413042363237464444453135383133363239413030464246343634373430413332433739303742354238343532343544394344414333463546363841363636
decrypt before data(1):48845A09A4FF5B012BBE42FC83F250B0AEA5D4FE1EA6A59BE813166C561EB1BA4F1744E79F50FC072016FF68384DCA1CA86B90BE50753956B9F1D5B68983F67C63EAF8ECFD62F1A6C3491469F6E6CFD8E895694678B2A24A9098FA120EF826C461B0ABF8B1B0C9E4EFD8E70547553068BA8560B61F7691E435E947E999A4B5C0
decrypt after:len(127),data(1):45414644453346434532314138303936413631424142423635394444444238393946384344323942323630343139394243314634323939334446414230394142464245364245363942374332393943424136373937454545323136363541463642363741383036314442453646413245423038323543333636444438313231
decrypt before data(2):3D940F0A14DA5A9838AAF70049C978529569667BB5D3191A7075A3DA53205EA2C74E4F3CF21814514A45275246CBB579F9768ED321BFEAA8CCED6C6EA683DD866CB5660B513360799D69C4CF6BEBDCD0A1976510A6C6FF19E6A4915B85A5533FE5644E4CD761B0A37F3D19004685C52C8A931F074DE15D615DA88C3E98D99FD4
decrypt after:len(2),data(2):3239
*******************************decrypt end*************************************
(256)18BB49FBC8AE1A82EECFECF8BB89C9D35FAAB857CC0C3B959DA3C3D513CAB255A0B627FDDE15813629A00FBF464740A32C7907B5B845245D9CDAC3F5F68A666EAFDE3FCE21A8096A61BABB659DDDB899F8CD29B2604199BC1F42993DFAB09ABFBE6BE69B7C299CBA6797EEE21665AF6B67A8061DBE6FA2EB0825C366DD812129
相关推荐
RSA签名验签工具是用于处理数字签名的一种实用软件,尤其在网络安全和电子商务中扮演着重要角色。这个名为“RSA签名验签工具windows_V1.4.zip”的压缩包包含了一个适用于Windows操作系统的工具,版本为V1.4,专门...
RSA2048是一种基于公钥密码体制的加密算法,由Ron Rivest、Adi Shamir和Leonard Adleman在1977年提出,是目前广泛使用的一种非对称加密技术。在这个标题和描述中,我们关注的是2048位的RSA算法,它在加密解密过程中...
### RSA与RSA2签名算法的区别 #### 数字签名概述 数字签名是一种确保数据完整性和验证发送者身份的技术手段。在实际应用中,数字签名通常包括两个步骤:摘要和非对称加密。首先,通过对需要签名的数据进行摘要处理...
在本文中,我们将深入探讨RSA2048的C语言实现及其相关知识点。 1. RSA算法基础: RSA算法由Ron Rivest、Adi Shamir和Leonard Adleman于1977年提出,它是一种非对称加密算法,意味着加密和解密使用不同的密钥。RSA...
C# 是一种广泛使用的编程语言,它提供了丰富的库来支持各种加密算法,其中包括RSA(Rivest-Shamir-Adleman)加密。RSA是一种非对称加密算法,它的特点是拥有两个密钥:公钥和私钥,分别用于加密和解密。 在这个"C# ...
易语言 rsa加密 易语言 rsa加密易语言 rsa加密
RSA加密算法是公钥密码学领域中的一个经典算法,由Ron Rivest、Adi Shamir和Leonard Adleman在1977年提出,因此得名RSA。它基于大整数因子分解的困难性,为数据通信提供安全的加密手段。在本压缩包文件中,我们可能...
在IT领域,特别是软件开发中,安全通信是至关重要的,而RSA算法是广泛使用的非对称加密技术之一。本文将详细讲解Delphi环境下如何实现RSA加解密,并着重讨论其支持的公钥加密私钥解密以及私钥加密公钥解密的功能,...
RSA算法是一种非对称加密算法,它在信息安全领域有着广泛的应用,如数字签名、数据加密等。这个"RSA-delphi7-XE.rar"压缩包包含了用Delphi编程语言实现的RSA算法,适用于Delphi XE版本。Delphi是Embarcadero ...
RSA(Rivest-Shamir-Adleman)是一种非对称加密算法,广泛应用于网络安全领域,包括数字签名、数据加密以及身份验证等。在这个场景中,"RSA离线签名工具"是一个专门用于生成和验证RSA数字签名的软件。下面我们将深入...
这个压缩包包含与RSA相关的JAR包、JavaScript文件以及Java工具类,主要用于在JSP应用中实现密码的加密和解密。以下是对这些资源及其在实际应用中的作用的详细解释。 1. RSA算法原理: RSA基于数论中的大数因子分解...
RSA2048签名算法是一种基于非对称加密技术的数字签名方法,广泛应用于网络安全、数据完整性保护以及身份验证等领域。在本文中,我们将深入探讨RSA2048签名算法的原理、工作流程以及其在实际应用中的重要性。 RSA...
RSA算法是一种非对称加密算法,由Ron Rivest、Adi Shamir和Leonard Adleman在1977年提出,是目前应用最广泛的公开密钥加密技术。该算法基于大数因子分解的数学难题,使得加密过程相对简单,但破解极其困难。 在RSA...
RSA算法是一种非对称加密算法,由Ron Rivest、Adi Shamir和Leonard Adleman在1977年提出,因其发明者的名字首字母而得名。在VC++中实现RSA算法需要理解其核心原理,包括大整数运算、素数检测、欧拉函数以及模逆运算...
RSA算法是一种非对称加密算法,它在信息安全领域有着广泛的应用,特别是在数据传输的安全性上。这个zip压缩包“rsa.zip”显然包含了关于RSA加密算法的实现,可能是一个C语言编写的程序“ras.c”。在这里,我们将深入...
RSA算法是一种非对称加密算法,它基于大数因子分解的困难性,广泛应用于网络安全领域,如数字签名、数据加密等。然而,RSA系统并非无懈可击,其中一种潜在的攻击方式就是“共模攻击”(Common Modulus Attack)。在...
RSA加密演算法是一种非对称加密演算法。在公开密钥加密和电子商业中RSA被广泛使用。 典型的应用 1. 苹果App签名, iOS App 签名的原理; 2. 支付宝签名验证 ; 2. HTTPS 加密连接; 3. 程序直接用RSA+AES加密通信 ...
RSA算法基于一个十分简单的数论事实:将两个大素数相乘十分容易,但是想要对其乘积进行因式分解却极其困难,因此可以将乘积公开作为加密密钥。RSA算法是第一个能同时用于加密和数字签名的算法,也易于理解和操作。...
本资源包含:RSA签名算法,格式为PKCS7。RSA签名算法,格式为PKCS7。RSA签名算法,格式为PKCS7。RSA签名算法,格式为PKCS7。 RSA加密算法是一种非对称加密算法。在公开密钥加密和电子商业中RSA被广泛使用。RSA是1977...
RSA算法是一种非对称加密算法,由Ron Rivest、Adi Shamir和Leonard Adleman在1977年提出,是目前广泛应用于网络安全领域的一种核心加密技术。它的主要特点是拥有两个密钥:公钥和私钥。公钥可以公开,用于加密信息;...