<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN" "http://www.wapforum.org/DTD/wml_1.1.xml">
<wml>
<head><meta forua="true" http-equiv="Cache-Control" content="max-age=0" /></head>
<card title="C# RSACryptoServiceProvider类实现RSA（非对称加密）算法（RSAHelper）" id="card1">
<p> 游客</p><p>
标题:C# RSACryptoServiceProvider类实现RSA（非对称加密）算法（RSAHelper）<br/>
正文:<br/>
1.首先介绍下什么是RSA算法,让大家对RSA算法有个简要的理解.   RSA算法非常简单，概述如下:找两素数p和q取n=p*q  如:n=3*7=21取t=(p-1)*(q-1) 如:t = 2*6 = 12 　 取任何一个数e,要求满足e 取d*e%t==1  如:d=7,e=7,则7*7/12刚好等于1满足要求这样最终得到三个数: n d e,即 n=21,d=7,e=7设消息为数M 设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。 2.上面就是对RSA算法的一个简要概括,该描述在很多书本上都有介绍,这里也就不做过多解释了,下面我们看下在.net 里面如何实现该算法.   在.net 里面,有一个叫RSACryptoServiceProvider的类,在MSDN中,我们可以了解到该类使用加密服务提供程序 (CSP) 提供的rsa算法的实现,执行不对称加密和解密,从继承关系上我们了解到该类继承自RSA类.通过该类,我们可以导出加密解密所需要的XML信息,并且能够根据我们提供的XML信息进行加密解密计算,下面是对该类的一些具体操作,主要包括如何导出密钥,如何用形成的密钥进行加密和解密,完成我们一般的操作.   public class Cyh_RSA    {        public Cyh_RSA()        {      &amp;<br/><a href="http://camnpr.com/wap.asp?mode=WAP&amp;act=View&amp;id=1938&amp;Page=1">[&lt;&lt;]</a><a href="http://camnpr.com/wap.asp?mode=WAP&amp;act=View&amp;id=1938&amp;Page=1">[[1]]</a><a href="http://camnpr.com/wap.asp?mode=WAP&amp;act=View&amp;id=1938&amp;Page=2">[2]</a><a href="http://camnpr.com/wap.asp?mode=WAP&amp;act=View&amp;id=1938&amp;Page=3">[3]</a><a href="http://camnpr.com/wap.asp?mode=WAP&amp;act=View&amp;id=1938&amp;Page=19">[&gt;&gt;]</a><br/>
<br/>
<a href="wap.asp?act=Com&amp;id=1938">查看评论(0)</a><br/>
<a href="wap.asp?act=AddCom&amp;inpId=1938">发表评论</a><br/><br/>

<br/>

<br/>
<a href="http://camnpr.com/wap.asp">首页</a>
</p>
</card>
</wml>