RSA做数字签名的几个问题

jingkingsoft 2005-06-14 11:13:34
RSA的Parameter里面的参数都是什么意思呢?
我看过的Moudle是放的PublicKey,那么D、P、DP、DQ…
开始的时候我该怎么样生成公钥和私钥?
RSAServiceProvider.ExportParameters()就可以了吗?
公钥可以保存到服务器上,那么私钥该怎么样存到证书里面
在本地安装证书用的是什么方法?

问题有点多,不好意思。分不够可以再加。
...全文
215 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
honghe1 2005-06-14
  • 打赏
  • 举报
回复
貌似楼主是金山软件的?我同学也在金山做,不过他们好象是用php的.
honghe1 2005-06-14
  • 打赏
  • 举报
回复
http://community.csdn.net/Expert/topic/4036/4036507.xml?temp=.1031916
这是我以前问这个问题的帖子,大家看看就知道我之前的绝望和痛苦。

在这里回帖,是希望和我一样的朋友少走弯路。

我也是刚刚学C#。大家做个朋友好了,互勉吧,哈哈。

我MSN:honghe1@hotmail.com
honghe1 2005-06-14
  • 打赏
  • 举报
回复
RSA的Parameter里面的参数都是什么意思呢?
我看过的Moudle是放的PublicKey,那么D、P、DP、DQ…
开始的时候我该怎么样生成公钥和私钥?
RSAServiceProvider.ExportParameters()就可以了吗?
公钥可以保存到服务器上,那么私钥该怎么样存到证书里面
在本地安装证书用的是什么方法?
-------------------------------------
我也是过来人,痛苦了好阵子了呢 .
---------------------
Parameter:是用来组装密钥的类,你可以创建他的一个实例来组装密钥(私钥,公钥)
这个实例有上面你说的属性 : D、P、DP、DQ....
但是如果是组装公钥的话,只要修改他的两个属性就好了:Moudle和Exponent
//加载对方的公钥
//{
//RSAParameters publicKeyParam=new RSAParameters();
publicKeyParam.Modulus = PublicKey;
publicKeyParam.Exponent = Exponent;
//}

//加载自己的密钥
////{
//RSAParameters privateKeyParam=new RSAParameters();
privateKeyParam.Modulus=mod;
privateKeyParam.Exponent=pubExp;
privateKeyParam.D=privExp;
privateKeyParam.P=p;
privateKeyParam.Q=q;
privateKeyParam.DP=DP;
privateKeyParam.DQ=DQ;
privateKeyParam.InverseQ=qInv;
---------------------------------------------------------------
RSAServiceProvider是用来作加密解密的,也是用来生成公钥密钥的.
他的实例默认是已经生成密钥了的。
RSAServiceProvider.ExportParameters(false)导私钥
RSAServiceProvider.ExportParameters(true)导公钥
有一点要说明的是,私钥里边已经包含了公钥的内容了。
公钥就是私钥里边的Moudle和Exponent字段(xml格式的)。
-----------------------------------------------------------
最后给你提供一个超链,非常有用,对你理解C#中的加密解密和数字签名非常有用。
http://www.koders.com/csharp/fid6E262438DA26758171EAC7AB3534B21E07AB9A26.aspx?s=RSACryptoServiceProvider
mbh0210 2005-06-14
  • 打赏
  • 举报
回复
学习...
zhongwanli 2005-06-14
  • 打赏
  • 举报
回复
DING LA
jingkingsoft 2005-06-14
  • 打赏
  • 举报
回复
另外,MSDN上小明、小红那一堆虽然讲了原理,但是具体的实现还是不甚了了。SighHash的后面一个参数是什么意思?RSA只能加密128位以内的数据,更大的数据怎么办?像SHA就有160、256、512三个长度,每个都超出这个加密限制。那个BigInterger好像不太可靠的说。
jingkingsoft 2005-06-14
  • 打赏
  • 举报
回复
55555555555
太感谢了
研究ing
唉,我也想去金山啊,但是目前还不想离开广州的说。另外,人家也不见得要:)
kingsoft已经名花有主啦,偶就不用冒名顶替了。jingking就是偶得名字,后面soft说明偶是搞软件开发D。
【课程介绍】     课程目标:             - 有状态登录和无状态登录的区别             - 常见的非对称加密算法和非对称的加密方式             - 老版本只使用jwt进行加密的弊端             - 授权中心的授权流程             - 如何整合网关组件实现jwt安全验证             - 理解什么是公钥什么是私钥      - 深刻理解授权流程什么是有状态? 有状态服务,即服务端需要记录每次会话的客户端信息,从而识别客户端身份,根据用户身份进行请求的处理,典型的设计如tomcat中的session。例如登录:用户登录后,我们把登录者的信息保存在服务端session中,并且给用户一个cookie值,记录对应的session。然后下次请求,用户携带cookie值来,我们就能识别到对应session,从而找到用户的信息。缺点是什么?- 服务端保存大量数据,增加服务端压力- 服务端保存用户状态,无法进行水平扩展- 客户端请求依赖服务端,多次请求必须访问同一台服务器。什么是无状态? 微服务集群中的每个服务,对外提供的都是Rest风格的接口。而Rest风格的一个最重要的规范就是:服务的无状态性,即:- 服务端不保存任何客户端请求者信息- 客户端的每次请求必须具备自描述信息,通过这些信息识别客户端身份带来的好处是什么呢?- 客户端请求不依赖服务端的信息,任何多次请求不需要必须访问到同一台服务- 服务端的集群和状态对客户端透明- 服务端可以任意的迁移和伸缩- 减小服务端存储压力

110,530

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧