- 浏览: 1011128 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (367)
- JavaScript (23)
- Java (60)
- Python (41)
- 其他 (36)
- SQL (4)
- 开发工具 (26)
- Linux (15)
- AJAX (6)
- Cache (3)
- 正则 (4)
- 架构 (9)
- 手机 (3)
- MySQL (4)
- Android (115)
- vps (1)
- 网站 (4)
- scale (3)
- 搜索引擎 (3)
- iPhone (2)
- hessian (1)
- hessdroid (1)
- 411 (1)
- jstat (1)
- gc (1)
- gallery (1)
- 惯性 (1)
- eclipse (1)
- mac wget error (1)
- miui file explorer 无用 解决办法 (1)
- vim (1)
最新评论
-
qingyezhangluo:
哎。楼主您既然是分享代码的为什么要加密的呢?而且问你密码还不回 ...
android应用换皮肤(转) -
MagicError:
kavoe 写道下载文件有密码。。。。
http抓包工具 -
knightdf:
我先试下再来
JAVA的RAS加密例子 -
kavoe:
下载文件有密码。。。。
http抓包工具 -
changanfounder:
hmc1985 写道setCallbackDuringFlin ...
android gallery滑动惯性问题
<一>基础
RSA算法非常简单,概述如下:
找两素数p和q
取n=p*q
取t=(p-1)*(q-1)
取任何一个数e,要求满足e<t并且e与t互素(就是最大公因数为1)
取d*e%t==1
这样最终得到三个数: n d e
设消息为数M (M <n)
设c=(M**d)%n就得到了加密后的消息c
设m=(c**e)%n则 m == M,从而完成对c的解密。
注:**表示次方,上面两式中的d和e可以互换。
在对称加密中:
n d两个数构成公钥,可以告诉别人;
n e两个数构成私钥,e自己保留,不让任何人知道。
给别人发送的信息使用e加密,只要别人能用d解开就证明信息是由你发送的,构成了签名机制。
别人给你发送信息时使用d加密,这样只有拥有e的你能够对其解密。
rsa的安全性在于对于一个大数n,没有有效的方法能够将其分解
从而在已知n d的情况下无法获得e;同样在已知n e的情况下无法
求得d。
<二>实践
接下来我们来一个实践,看看实际的操作:
找两个素数:
p=47
q=59
这样
n=p*q=2773
t=(p-1)*(q-1)=2668
取e=63,满足e<t并且e和t互素
用perl简单穷举可以获得满主 e*d%t ==1的数d:
C:\Temp>perl -e "foreach $i (1..9999){ print($i),last if $i*63%2668==1 }"
847
即d=847
最终我们获得关键的
n=2773
d=847
e=63
取消息M=244我们看看
加密:
c=M**d%n = 244**847%2773
用perl的大数计算来算一下:
C:\Temp>perl -Mbigint -e "print 244**847%2773"
465
即用d对M加密后获得加密信息c=465
解密:
我们可以用e来对加密后的c进行解密,还原M:
m=c**e%n=465**63%2773 :
C:\Temp>perl -Mbigint -e "print 465**63%2773"
244
即用e对c解密后获得m=244 , 该值和原始信息M相等。
<三>字符串加密
把上面的过程集成一下我们就能实现一个对字符串加密解密的示例了。
每次取字符串中的一个字符的ascii值作为M进行计算,其输出为加密后16进制
的数的字符串形式,按3字节表示,如01F
代码如下:
#!/usr/bin/perl -w
#RSA 计算过程学习程序编写的测试程序
#watercloud 2003-8-12
#
use strict;
use Math::BigInt;
my %RSA_CORE = (n=>2773,e=>63,d=>847); #p=47,q=59
my $N=new Math::BigInt($RSA_CORE{n});
my $E=new Math::BigInt($RSA_CORE{e});
my $D=new Math::BigInt($RSA_CORE{d});
print "N=$N D=$D E=$E\n";
sub RSA_ENCRYPT
{
my $r_mess = shift @_;
my ($c,$i,$M,$C,$cmess);
for($i=0;$i < length($$r_mess);$i++)
{
$c=ord(substr($$r_mess,$i,1));
$M=Math::BigInt->new($c);
$C=$M->copy(); $C->bmodpow($D,$N);
$c=sprintf "%03X",$C;
$cmess.=$c;
}
return \$cmess;
}
sub RSA_DECRYPT
{
my $r_mess = shift @_;
my ($c,$i,$M,$C,$dmess);
for($i=0;$i < length($$r_mess);$i+=3)
{
$c=substr($$r_mess,$i,3);
$c=hex($c);
$M=Math::BigInt->new($c);
$C=$M->copy(); $C->bmodpow($E,$N);
$c=chr($C);
$dmess.=$c;
}
return \$dmess;
}
my $mess="RSA 娃哈哈哈~~~";
$mess=$ARGV[0] if @ARGV >= 1;
print "原始串:",$mess,"\n";
my $r_cmess = RSA_ENCRYPT(\$mess);
print "加密串:",$$r_cmess,"\n";
my $r_dmess = RSA_DECRYPT($r_cmess);
print "解密串:",$$r_dmess,"\n";
#EOF
测试一下:
C:\Temp>perl rsa-test.pl
N=2773 D=847 E=63
原始串:RSA 娃哈哈哈~~~
加密串:5CB6CD6BC58A7709470AA74A0AA74A0AA74A6C70A46C70A46C70A4
解密串:RSA 娃哈哈哈~~~
C:\Temp>perl rsa-test.pl 安全焦点(xfocus)
N=2773 D=847 E=63
原始串:安全焦点(xfocus)
加密串:3393EC12F0A466E0AA9510D025D7BA0712DC3379F47D51C325D67B
解密串:安全焦点(xfocus)
<四>提高
前面已经提到,rsa的安全来源于n足够大,我们测试中使用的n是非常小的,根本不能保障安全性,
我们可以通过RSAKit、RSATool之类的工具获得足够大的N 及D E。
通过工具,我们获得1024位的N及D E来测试一下:
n=0x328C74784DF31119C526D18098EBEBB943B0032B599CEE13CC2BCE7B5FCD15F90B66EC3A85F5005D
BDCDED9BDFCB3C4C265AF164AD55884D8278F791C7A6BFDAD55EDBC4F017F9CCF1538D4C2013433B383B
47D80EC74B51276CA05B5D6346B9EE5AD2D7BE7ABFB36E37108DD60438941D2ED173CCA50E114705D7E2
BC511951
d=0x10001
e=0xE760A3804ACDE1E8E3D7DC0197F9CEF6282EF552E8CEBBB7434B01CB19A9D87A3106DD28C523C2995
4C5D86B36E943080E4919CA8CE08718C3B0930867A98F635EB9EA9200B25906D91B80A47B77324E66AFF2
C4D70D8B1C69C50A9D8B4B7A3C9EE05FFF3A16AFC023731D80634763DA1DCABE9861A4789BD782A592D2B
1965
设原始信息
M=0x11111111111122222222222233333333333
完成这么大数字的计算依赖于大数运算库,用perl来运算非常简单:
A) 用d对M进行加密如下:
c=M**d%n :
C:\Temp>perl -Mbigint -e " $x=Math::BigInt->bmodpow(0x11111111111122222222222233
333333333, 0x10001, 0x328C74784DF31119C526D18098EBEBB943B0032B599CEE13CC2BCE7B5F
CD15F90B66EC3A85F5005DBDCDED9BDFCB3C4C265AF164AD55884D8278F791C7A6BFDAD55EDBC4F0
17F9CCF1538D4C2013433B383B47D80EC74B51276CA05B5D6346B9EE5AD2D7BE7ABFB36E37108DD6
0438941D2ED173CCA50E114705D7E2BC511951);print $x->as_hex"
0x17b287be418c69ecd7c39227ab681ac422fcc84bb35d8a632543b304de288a8d4434b73d2576bd
45692b007f3a2f7c5f5aa1d99ef3866af26a8e876712ed1d4cc4b293e26bc0a1dc67e247715caa6b
3028f9461a3b1533ec0cb476441465f10d8ad47452a12db0601c5e8beda686dd96d2acd59ea89b91
f1834580c3f6d90898
即用d对M加密后信息为:
c=0x17b287be418c69ecd7c39227ab681ac422fcc84bb35d8a632543b304de288a8d4434b73d2576bd
45692b007f3a2f7c5f5aa1d99ef3866af26a8e876712ed1d4cc4b293e26bc0a1dc67e247715caa6b
3028f9461a3b1533ec0cb476441465f10d8ad47452a12db0601c5e8beda686dd96d2acd59ea89b91
f1834580c3f6d90898
B) 用e对c进行解密如下:
m=c**e%n :
C:\Temp>perl -Mbigint -e " $x=Math::BigInt->bmodpow(0x17b287be418c69ecd7c39227ab
681ac422fcc84bb35d8a632543b304de288a8d4434b73d2576bd45692b007f3a2f7c5f5aa1d99ef3
866af26a8e876712ed1d4cc4b293e26bc0a1dc67e247715caa6b3028f9461a3b1533ec0cb4764414
65f10d8ad47452a12db0601c5e8beda686dd96d2acd59ea89b91f1834580c3f6d90898, 0xE760A
3804ACDE1E8E3D7DC0197F9CEF6282EF552E8CEBBB7434B01CB19A9D87A3106DD28C523C29954C5D
86B36E943080E4919CA8CE08718C3B0930867A98F635EB9EA9200B25906D91B80A47B77324E66AFF
2C4D70D8B1C69C50A9D8B4B7A3C9EE05FFF3A16AFC023731D80634763DA1DCABE9861A4789BD782A
592D2B1965, 0x328C74784DF31119C526D18098EBEBB943B0032B599CEE13CC2BCE7B5FCD15F90
B66EC3A85F5005DBDCDED9BDFCB3C4C265AF164AD55884D8278F791C7A6BFDAD55EDBC4F017F9CCF
1538D4C2013433B383B47D80EC74B51276CA05B5D6346B9EE5AD2D7BE7ABFB36E37108DD60438941
D2ED173CCA50E114705D7E2BC511951);print $x->as_hex"
0x11111111111122222222222233333333333
(我的P4 1.6G的机器上计算了约5秒钟)
得到用e解密后的m=0x11111111111122222222222233333333333 == M
C) RSA通常的实现
RSA简洁幽雅,但计算速度比较慢,通常加密中并不是直接使用RSA 来对所有的信息进行加密,
最常见的情况是随机产生一个对称加密的密钥,然后使用对称加密算法对信息加密,之后用
RSA对刚才的加密密钥进行加密。
最后需要说明的是,当前小于1024位的N已经被证明是不安全的
自己使用中不要使用小于1024位的RSA,最好使用2048位的。
----------------------------------------------------------
一个简单的RSA算法实现JAVA源代码:
filename:RSA.java
<script src="/plug-ins/SyntaxHighlighter/shCore.js"></script>
- /*
- * Created on Mar 3, 2005
- *
- * TODO To change the template for this generated file go to
- * Window - Preferences - Java - Code Style - Code Templates
- */
- import java.math.BigInteger;
- import java.io.InputStream;
- import java.io.OutputStream;
- import java.io.FileInputStream;
- import java.io.FileOutputStream;
- import java.io.FileNotFoundException;
- import java.io.IOException;
- import java.io.FileWriter;
- import java.io.FileReader;
- import java.io.BufferedReader;
- import java.util.StringTokenizer;
- /**
- * @author Steve
- *
- * TODO To change the template for this generated type comment go to
- * Window - Preferences - Java - Code Style - Code Templates
- */
- public class RSA {
- /**
- * BigInteger.ZERO
- */
- private static final BigInteger ZERO = BigInteger.ZERO;
- /**
- * BigInteger.ONE
- */
- private static final BigInteger ONE = BigInteger.ONE;
- /**
- * Pseudo BigInteger.TWO
- */
- private static final BigInteger TWO = new BigInteger("2");
- private BigInteger myKey;
- private BigInteger myMod;
- private int blockSize;
- public RSA (BigInteger key, BigInteger n, int b) {
- myKey = key;
- myMod = n;
- blockSize = b;
- }
- public void encodeFile (String filename) {
- byte[] bytes = new byte[blockSize / 8 + 1];
- byte[] temp;
- int tempLen;
- InputStream is = null;
- FileWriter writer = null;
- try {
- is = new FileInputStream(filename);
- writer = new FileWriter(filename + ".enc");
- }
- catch (FileNotFoundException e1){
- System.out.println("File not found: " + filename);
- }
- catch (IOException e1){
- System.out.println("File not found: " + filename + ".enc");
- }
- /**
- * Write encoded message to 'filename'.enc
- */
- try {
- while ((tempLen = is.read(bytes, 1, blockSize / 8)) > 0) {
- for (int i = tempLen + 1; i < bytes.length; ++i) {
- bytes[i] = 0;
- }
- writer.write(encodeDecode(new BigInteger(bytes)) + " ");
- }
- }
- catch (IOException e1) {
- System.out.println("error writing to file");
- }
- /**
- * Close input stream and file writer
- */
- try {
- is.close();
- writer.close();
- }
- catch (IOException e1) {
- System.out.println("Error closing file.");
- }
- }
- public void decodeFile (String filename) {
- FileReader reader = null;
- OutputStream os = null;
- try {
- reader = new FileReader(filename);
- os = new FileOutputStream(filename.replaceAll(".enc", ".dec"));
- }
- catch (FileNotFoundException e1) {
- if (reader == null)
- System.out.println("File not found: " + filename);
- else
- System.out.println("File not found: " + filename.replaceAll(".enc", "dec"));
- }
- BufferedReader br = new BufferedReader(reader);
- int offset;
- byte[] temp, toFile;
- StringTokenizer st = null;
- try {
- while (br.ready()) {
- st = new StringTokenizer(br.readLine());
- while (st.hasMoreTokens()){
- toFile = encodeDecode(new BigInteger(st.nextToken())).toByteArray();
- System.out.println(toFile.length + " x " + (blockSize / 8));
- if (toFile[0] == 0 && toFile.length != (blockSize / 8)) {
- temp = new byte[blockSize / 8];
- offset = temp.length - toFile.length;
- for (int i = toFile.length - 1; (i <= 0) && ((i + offset) <= 0); --i) {
- temp[i + offset] = toFile[i];
- }
- toFile = temp;
- }
- /*if (toFile.length != ((blockSize / 8) + 1)){
- temp = new byte[(blockSize / 8) + 1];
- System.out.println(toFile.length + " x " + temp.length);
- for (int i = 1; i < temp.length; i++) {
- temp[i] = toFile[i - 1];
- }
- toFile = temp;
- }
- else
- System.out.println(toFile.length + " " + ((blockSize / 8) + 1));*/
- os.write(toFile);
- }
- }
- }
- catch (IOException e1) {
- System.out.println("Something went wrong");
- }
- /**
- * close data streams
- */
- try {
- os.close();
- reader.close();
- }
- catch (IOException e1) {
- System.out.println("Error closing file.");
- }
- }
- /**
- * Performs <tt>base</tt>^<sup><tt>pow</tt></sup> within the modular
- * domain of <tt>mod</tt>.
- *
- * @param base the base to be raised
- * @param pow the power to which the base will be raisded
- * @param mod the modular domain over which to perform this operation
- * @return <tt>base</tt>^<sup><tt>pow</tt></sup> within the modular
- * domain of <tt>mod</tt>.
- */
- public BigInteger encodeDecode(BigInteger base) {
- BigInteger a = ONE;
- BigInteger s = base;
- BigInteger n = myKey;
- while (!n.equals(ZERO)) {
- if(!n.mod(TWO).equals(ZERO))
- a = a.multiply(s).mod(myMod);
- s = s.pow(2).mod(myMod);
- n = n.divide(TWO);
- }
- return a;
- }
- }
在这里提供两个版本的RSA算法JAVA实现的代码下载:
1. 来自于 http://www.javafr.com/code.aspx?ID=27020 的RSA算法实现源代码包:
JavaFR_RSA_Source.rar
2. 来自于 http://www.ferrara.linux.it/Members/lucabariani/RSA/implementazioneRsa/ 的实现:
sorgentiJava.tar.gz - 源代码包
algoritmoRSA.jar - 编译好的jar包
另外关于RSA算法的php实现请参见文章: php下的RSA算法实现
关于使用VB实现RSA算法的源代码下载(此程序采用了psc1算法来实现快速的RSA加密):
vb_PSC1_RSA.rar
RSA加密的JavaScript实现: http://www.ohdave.com/rsa/
发表评论
-
android屏幕适配
2012-11-16 17:24 2194屏幕适配一直是一个让人头疼的问题,论坛上讨论这个问题的最后也 ... -
禁止Eclipse中xml文件Run as的XSL Transformation生成out.xml以方便Android应用开发
2012-08-26 21:38 2641可以在Eclipse里面配置,菜单Windows->P ... -
android 自带的主题 theme 的使用
2012-08-25 23:21 2372在android的sdk 安装目录data\r ... -
android开发之gallery 实现滚动一张且短距离滑动实现滚动
2011-12-19 18:50 1928首先gallery的特点就不用多说了吧,惯性滚动、半屏翻页,但 ... -
使用Jstat监控gc情况(收藏)
2011-12-19 13:22 1859性能测试过程中,我们 ... -
eclipse生成javadoc乱码解决
2011-10-24 09:37 1291eclipse在生成javadoc的时候出现乱码,是因为 ... -
java中在静态方法或变量中动态获取当前类的类名
2011-10-14 11:20 3702java中在静态方法中动态获取当前类的类名或者动态获取当前类的 ... -
飞鸽传书实现原理
2011-10-13 11:35 3260飞鸽传书的实现原理: (1)最关键的是局域网用户列表的 ... -
Android开发——利用Cursor+CursorAdapter实现界面实时更新(转)
2011-09-20 15:47 3084好久没有更新博客了 ... -
Nginx使用反向代理时 Hessian 的 411 错误解决方案【转】
2011-09-15 13:48 2361问题描述: 用 Hessian 实现 web se ... -
"Copy" did not complete normally. Please see the log for more information.
2011-05-06 17:19 4040在用android日志的时候老是弹出一个窗口,内容 ... -
jdk api下载地址备份
2011-02-15 10:58 1586中文jdk6的api: JDK6 API 中文版 H ... -
JAVA NIO 简介(转)
2010-12-09 13:03 1062http://www.iteye.com/topic/8344 ... -
netty的资料
2010-10-31 16:06 1290http://hornetq.sourceforge.net/ ... -
Java程序发邮件小例子(转载收藏)
2010-10-27 21:25 1561今天试了一个Java写的发邮件小例子,需要的jar包有 ... -
使用Netty 构造一个异步的httpclient
2010-09-21 00:35 7839原文地址:http://dev.firnow.com/co ... -
Netty使用初步
2010-09-21 00:26 13970收藏自:http://www.kafk ... -
集群环境下SESSION处理(转)
2010-09-08 15:24 1844本文转自:http://blog.csdn.net/l ... -
Java集合的Stack、Queue、Map的遍历
2010-09-08 13:00 1440在集合操作中,常常 ... -
<转>,防止刷新/后退引起的重复提交问题的Java Token代码,非Struts
2009-12-10 13:31 1917贴子转自http://hi.baidu.com/bobylou ...
相关推荐
在`RSADemo`这个示例中,可能包含了完整的RSA算法Java实现,包括密钥对的生成、加密和解密的过程。你可以通过阅读和理解这个示例代码,深入学习RSA算法在实际项目中的应用。 总的来说,RSA算法在Java中的实现涉及了...
本篇将深入探讨RSA算法的理论基础及其在C++和Java两种编程语言中的实现。 RSA算法的基本思想是基于两个大素数的乘积。两个大素数只有两个较小的因子1和自身,但找到这两个因子对于大整数来说极其困难。因此,RSA...
下面将详细介绍RSA加密算法的原理以及如何在Java中进行实现。 **RSA算法简介** RSA是由Ron Rivest、Adi Shamir和Leonard Adleman在1977年提出的,是一种非对称加密算法。它基于两个密钥:公钥和私钥。公钥用于加密...
在使用Java语言实现RSA算法时,首先需要理解RSA算法的基本原理,包括模数的生成、密钥对的产生、加密和解密的过程等。在Java中实现RSA算法的关键步骤包括: 1. 导入Java的加密库,如java.security等。 2. 使用...
### RSA算法实现报告 #### 实验环境 - **硬件配置**:处理器:Intel(R) Core(TM) i5-2430M CPU @ 2.40GHz (4CPUs), ~2.4GHz;内存:2048MB RAM - **软件工具**: - 操作系统:Windows 7 旗舰版 - 开发工具:...
RSA算法基于大数分解难题的原理,使用公钥加密、私钥解密的方式实现信息的加密和解密。 知识点2:Java中RSA加密解密算法的实现 在Java中,可以使用Java Cryptography Architecture(JCA)来实现RSA加密解密算法。...
RSAPrivateKey prk = (RSAPrivateKey) b.readObject(); BigInteger d = prk.getPrivateExponent(); // 获取私钥参数及解密 BigInteger n = prk.getModulus(); System.out.println("d= " + d); System.out...
在Java中实现RSA加密算法,通常涉及到以下几个关键知识点: 1. **密钥生成**:RSA的核心是生成一对密钥,即公钥和私钥。在Java中,我们使用`java.security.KeyPairGenerator`类来生成密钥对。首先,我们需要实例化...
java利用大整数类实现的一个RSA加解密签名过程。
为了实现C#与Java之间的互通加解密,需要确保两边使用的RSA算法实现一致,包括密钥生成、填充算法及加密解密的具体实现。 - **密钥一致性**:确保C#与Java生成的公私钥对相同。 - **填充算法一致性**:两边都应采用...
在Java中实现RSA算法,主要涉及到`java.security`和`javax.crypto`这两个包中的类。 1. **RSA算法原理** RSA算法的核心是欧拉定理和费马小定理。两个大素数p和q相乘得到n=p*q,计算φ(n)=(p-1)*(q-1),然后选取一...
Java实现RSA算法时,通常会用到`java.security`和`javax.crypto`这两个包中的类。模的重复平方算法(也称为快速幂运算)用于高效地计算大整数的幂,而中国剩余定理(Chinese Remainder Theorem, CRT)则在某些情况下...
### RSA加解密算法Java实现解析 #### 一、引言 RSA算法是一种非对称加密算法,在现代信息安全领域有着广泛的应用。它基于大整数分解的数学难题,确保了其安全性。本文将通过分析提供的Java代码来深入了解RSA算法的...
这个RAR压缩包包含了一个名为“Rsa.java”的源代码文件,可能是用于演示如何在Java环境中实现RSA算法。另一个文件“www.pudn.com.txt”可能是辅助资料,可能包含了关于算法的解释或者是一些额外的说明。 RSA算法由...
在Java平台上实现RSA算法,你需要了解以下关键概念和步骤: 1. **密钥生成**:RSA算法需要用到一对公钥和私钥。公钥可以公开,用于加密;私钥必须保密,用于解密。在Java中,我们可以使用`java.security....
这里我们将深入探讨RSA算法的原理、实现方式以及Java中的应用。 RSA算法的核心包括四个主要步骤: 1. **密钥生成**: - 首先,随机选择两个大素数p和q,它们是私钥的一部分。 - 计算n=p*q,n是公钥和私钥的共同...
下面将详细介绍Java实现的数字签名算法RSA的相关概念、原理、实现方法及操作技巧。 背景介绍 数字签名是一种带有密钥(公钥、私钥)的消息摘要算法。其主要功能是验证数据完整性、认证数据来源、抗否认。在数字...
RSA算法涉及到两个密钥:公钥(用于加密数据)和私钥(用于解密数据)。这两个密钥数学上是相关的,但一个密钥很难从另一个密钥推导出来。 ### Java实现RSA加密算法的关键步骤 #### 1. 生成质数 RSA加密算法的基础...
Java 实现文件的 RSA 和 DES 加密 在现代密码技术中,根据密钥类型的不同,可以将其分为两类:对称加密算法(秘密...本文介绍了 Java 实现文件的 RSA 和 DES 加密的方法,并讨论了加密算法的选择和密钥管理的重要性。