日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java rsa算法_求RSA算法JAVA实现源代码(带界面的)

發(fā)布時(shí)間:2025/3/12 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java rsa算法_求RSA算法JAVA实现源代码(带界面的) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

展開全部

import javax.crypto.Cipher;

import java.security.*;

import java.security.spec.RSAPublicKeySpec;

import java.security.spec.RSAPrivateKeySpec;

import java.security.spec.InvalidKeySpecException;

import java.security.interfaces.RSAPrivateKey;

import java.security.interfaces.RSAPublicKey;

import java.io.*;

import java.math.BigInteger;

/**

* RSA 工具類。提供加密,解密,生成密62616964757a686964616fe59b9ee7ad9431333234326339鑰對(duì)等方法。

* 需要到http://www.bouncycastle.org下載bcprov-jdk14-123.jar。

* @author xiaoyusong

* mail: xiaoyusong@etang.com

* msn:xiao_yu_song@hotmail.com

* @since 2004-5-20

*

*/

public class RSAUtil {

/**

* 生成密鑰對(duì)

* @return KeyPair

* @throws EncryptException

*/

public static KeyPair generateKeyPair() throws EncryptException {

try {

KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("RSA",

new org.bouncycastle.jce.provider.BouncyCastleProvider());

final int KEY_SIZE = 1024;//沒什么好說的了,這個(gè)值關(guān)系到塊加密的大小,可以更改,但是不要太大,否則效率會(huì)低

keyPairGen.initialize(KEY_SIZE, new SecureRandom());

KeyPair keyPair = keyPairGen.genKeyPair();

return keyPair;

} catch (Exception e) {

throw new EncryptException(e.getMessage());

}

}

/**

* 生成公鑰

* @param modulus

* @param publicExponent

* @return RSAPublicKey

* @throws EncryptException

*/

public static RSAPublicKey generateRSAPublicKey(byte[] modulus, byte[] publicExponent) throws EncryptException {

KeyFactory keyFac = null;

try {

keyFac = KeyFactory.getInstance("RSA", new org.bouncycastle.jce.provider.BouncyCastleProvider());

} catch (NoSuchAlgorithmException ex) {

throw new EncryptException(ex.getMessage());

}

RSAPublicKeySpec pubKeySpec = new RSAPublicKeySpec(new BigInteger(modulus), new BigInteger(publicExponent));

try {

return (RSAPublicKey) keyFac.generatePublic(pubKeySpec);

} catch (InvalidKeySpecException ex) {

throw new EncryptException(ex.getMessage());

}

}

/**

* 生成私鑰

* @param modulus

* @param privateExponent

* @return RSAPrivateKey

* @throws EncryptException

*/

public static RSAPrivateKey generateRSAPrivateKey(byte[] modulus, byte[] privateExponent) throws EncryptException {

KeyFactory keyFac = null;

try {

keyFac = KeyFactory.getInstance("RSA", new org.bouncycastle.jce.provider.BouncyCastleProvider());

} catch (NoSuchAlgorithmException ex) {

throw new EncryptException(ex.getMessage());

}

RSAPrivateKeySpec priKeySpec = new RSAPrivateKeySpec(new BigInteger(modulus), new BigInteger(privateExponent));

try {

return (RSAPrivateKey) keyFac.generatePrivate(priKeySpec);

} catch (InvalidKeySpecException ex) {

throw new EncryptException(ex.getMessage());

}

}

/**

* 加密

* @param key 加密的密鑰

* @param data 待加密的明文數(shù)據(jù)

* @return 加密后的數(shù)據(jù)

* @throws EncryptException

*/

public static byte[] encrypt(Key key, byte[] data) throws EncryptException {

try {

Cipher cipher = Cipher.getInstance("RSA", new org.bouncycastle.jce.provider.BouncyCastleProvider());

cipher.init(Cipher.ENCRYPT_MODE, key);

int blockSize = cipher.getBlockSize();//獲得加密塊大小,如:加密前數(shù)據(jù)為128個(gè)byte,而key_size=1024 加密塊大小為127 byte,加密后為128個(gè)byte;因此共有2個(gè)加密塊,第一個(gè)127 byte第二個(gè)為1個(gè)byte

int outputSize = cipher.getOutputSize(data.length);//獲得加密塊加密后塊大小

int leavedSize = data.length % blockSize;

int blocksSize = leavedSize != 0 ? data.length / blockSize + 1 : data.length / blockSize;

byte[] raw = new byte[outputSize * blocksSize];

int i = 0;

while (data.length - i * blockSize > 0) {

if (data.length - i * blockSize > blockSize)

cipher.doFinal(data, i * blockSize, blockSize, raw, i * outputSize);

else

cipher.doFinal(data, i * blockSize, data.length - i * blockSize, raw, i * outputSize);

//這里面doUpdate方法不可用,查看源代碼后發(fā)現(xiàn)每次doUpdate后并沒有什么實(shí)際動(dòng)作除了把byte[]放到ByteArrayOutputStream中,而最后doFinal的時(shí)候才將所有的byte[]進(jìn)行加密,可是到了此時(shí)加密塊大小很可能已經(jīng)超出了OutputSize所以只好用dofinal方法。

i++;

}

return raw;

} catch (Exception e) {

throw new EncryptException(e.getMessage());

}

}

/**

* 解密

* @param key 解密的密鑰

* @param raw 已經(jīng)加密的數(shù)據(jù)

* @return 解密后的明文

* @throws EncryptException

*/

public static byte[] decrypt(Key key, byte[] raw) throws EncryptException {

try {

Cipher cipher = Cipher.getInstance("RSA", new org.bouncycastle.jce.provider.BouncyCastleProvider());

cipher.init(cipher.DECRYPT_MODE, key);

int blockSize = cipher.getBlockSize();

ByteArrayOutputStream bout = new ByteArrayOutputStream(64);

int j = 0;

while (raw.length - j * blockSize > 0) {

bout.write(cipher.doFinal(raw, j * blockSize, blockSize));

j++;

}

return bout.toByteArray();

} catch (Exception e) {

throw new EncryptException(e.getMessage());

}

}

/**

*

* @param args

* @throws Exception

*/

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

File file = new File("test.html");

FileInputStream in = new FileInputStream(file);

ByteArrayOutputStream bout = new ByteArrayOutputStream();

byte[] tmpbuf = new byte[1024];

int count = 0;

while ((count = in.read(tmpbuf)) != -1) {

bout.write(tmpbuf, 0, count);

tmpbuf = new byte[1024];

}

in.close();

byte[] orgData = bout.toByteArray();

KeyPair keyPair = RSAUtil.generateKeyPair();

RSAPublicKey pubKey = (RSAPublicKey) keyPair.getPublic();

RSAPrivateKey priKey = (RSAPrivateKey) keyPair.getPrivate();

byte[] pubModBytes = pubKey.getModulus().toByteArray();

byte[] pubPubExpBytes = pubKey.getPublicExponent().toByteArray();

byte[] priModBytes = priKey.getModulus().toByteArray();

byte[] priPriExpBytes = priKey.getPrivateExponent().toByteArray();

RSAPublicKey recoveryPubKey = RSAUtil.generateRSAPublicKey(pubModBytes,pubPubExpBytes);

RSAPrivateKey recoveryPriKey = RSAUtil.generateRSAPrivateKey(priModBytes,priPriExpBytes);

byte[] raw = RSAUtil.encrypt(priKey, orgData);

file = new File("encrypt_result.dat");

OutputStream out = new FileOutputStream(file);

out.write(raw);

out.close();

byte[] data = RSAUtil.decrypt(recoveryPubKey, raw);

file = new File("decrypt_result.html");

out = new FileOutputStream(file);

out.write(data);

out.flush();

out.close();

}

}

http://book.77169.org/data/web5409/20050328/20050328__3830259.html

這個(gè)行吧

http://soft.zdnet.com.cn/software_zone/2007/0925/523319.shtml

再參考這個(gè)吧

http://topic.csdn.net/t/20040427/20/3014655.html

已贊過

已踩過<

你對(duì)這個(gè)回答的評(píng)價(jià)是?

評(píng)論

收起

總結(jié)

以上是生活随笔為你收集整理的java rsa算法_求RSA算法JAVA实现源代码(带界面的)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲美女久久 | 国产精品视频久久久久 | 一本大道东京热无码 | 久久橹 | 亚洲精品女人久久久 | 欧美黄色影院 | 免费看片网站91 | 亚洲天堂av女优 | 日韩在线看片 | 尤物在线观看 | 亚洲欧美一级 | 青青青视频在线 | 中国无码人妻丰满熟妇啪啪软件 | 亚洲av男人的天堂在线观看 | 天天天操操操 | 日本人妻丰满熟妇久久久久久 | 欧美日韩国产精品一区二区 | 国产免费91视频 | 打美女白嫩屁屁网站 | 女子spa高潮呻吟抽搐 | 国产免费av网 | 姝姝窝人体www聚色窝 | 国精品无码一区二区三区 | 日韩欧美视频免费在线观看 | 少妇婷婷| 青青草色视频 | 国产一区 在线播放 | 亚洲一区h | 四虎国产精品永久免费观看视频 | 亚洲午夜久久久久 | 欧美一区影院 | 精品国产亚洲一区二区麻豆 | 97中文字幕 | 亚洲欧美国产日韩精品 | 奇米99 | 国产性色av | 欧美性视频一区二区 | 日韩国产成人在线 | 综合网在线视频 | 嫩草视频网站 | 在线看三级| 亚洲在线观看免费视频 | 日本爽爽爽爽爽爽在线观看免 | 欧美日韩亚洲高清 | 亚洲精品二三区 | 色中色综合| 久久1234 | 精品一区二区精品 | fc2ppv色の美マンに中出し | 日韩欧美一区二区三区免费观看 | 国产做爰全过程免费视频 | 国产乱国产 | 黄色精品网站 | 欧美视频一区二区在线 | 香蕉久久一区二区三区 | 国产老熟女一区二区三区 | 亚洲色图av在线 | 免费网站黄色 | 久久亚洲中文字幕无码 | 免费激情片 | 国产精品久久不卡 | av大帝| 一本一道久久a久久精品蜜桃 | 亚洲av无码精品一区二区 | 欧美 日韩 国产 中文 | 中国xxxx性xxxx产国 | avtt亚洲天堂| 欧美作爱视频 | 色综合久久网 | 中文字幕在线观看一区二区三区 | 大香蕉精品一区 | 进去里在线观看 | 理论视频在线观看 | 色哟哟精品观看 | 九七影院在线观看免费观看电视 | 九热在线| 亚洲精品视频一区二区三区 | 日日夜夜国产精品 | 久久亚洲av无码西西人体 | 国产av无码专区亚洲av | 中文字幕精品久久 | 男人干女人视频 | 中文精品久久 | 中文字幕在线免费 | 国产精品美女久久久久 | 奇米影视网 | 免费在线色视频 | 欧美人与禽zozzo性之恋的特点 | 99国产免费 | 韩国视频一区二区三区 | 大尺度床戏视频 | 日韩一区二区在线观看 | 久久久久久久久久影视 | 亚洲综合狠狠 | 污视频在线播放 | 精品丰满少妇一区二区三区 | 国产视频一区二区三区在线 | 久艹av| 亚州av综合色区无码一区 |