2 u012718456 u012718456 于 2016.09.20 17:26 提问

C# 关于数字签名的一些问题请教
                    string date = HttpServiceByForm("http://192.168.1.1:8888:/accessToken/nonce", "openId=openApiTest");
        string[] sArray = date.Split('"');
        byte[] rgbHash = Convert.FromBase64String(sArray[7]);
        X509Certificate2 objx5092 = new X509Certificate2(@"..\Plugs\certifivate\服务通讯证书.pfx", "1234");
        RSACryptoServiceProvider rsa = objx5092.PrivateKey as System.Security.Cryptography.RSACryptoServiceProvider;10             byte[] rgbHash = Convert.FromBase64String(sArray[7]);11             //md5 你懂的 返回byte[]
        byte[] bb = rsa.SignData(rgbHasH, "MD5");
        //将md5 之后的数据进行base64编码 必须的 返回的就是已签名的数据 
        string signature = System.Convert.ToBase64String(bb);

        //string  xmlprivate =  objx5092.PrivateKey.ToXmlString(true);

        return signature;//将签名转化base64
        return byteToHexStr(bb);///将签名结果转化为16进制字符串
    }


            代码在上面,现在我要签名后的格式是  c0acd8832b574243b5938afc183ec760 这样的  

但是 上面的代码的结果是128位数据 各位大神求教

1个回答

caozhy
caozhy   Ds   Rxr 2016.09.20 20:04

string signature = System.Convert.ToBase64String(bb);
这一步是多余的。
直接
string result = "";
for (int i = 0; i < bb.GetLength(0); i++)
result += Convert.ToString(bb[i], 16).PadLeft(2, '0');

u012718456
u012718456 像这种 c0acd8832b574243b5938afc183ec760
接近 2 年之前 回复
u012718456
u012718456 我想要的是32位的字符
接近 2 年之前 回复
u012718456
u012718456 这种得到的结果 07151f61ff1f21d8ad2178345dcd8c928ae088b98d0f8f9ac1d3dbc8f86904e964ae488d3a210adba170565df8217747687013bb283c5eec5d5d2017d4977b996ed4e32c24dcf013cbd3a14d05661817bf862ca90c91e01d5b509cbb6ce1b27aaac70667130e20fd7e339a849de9e227a68ab6a6ec09f53fe070473f84ac1d99
接近 2 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
过滤器,拦截器,监听器具体应用上的区别
过滤器 拦截器 监听器
请教C#网络编程一些问题!
我是用TcpLister和TCPclient编写网络传输一些东西!但是如果客户端断开!服务i器怎么知道呢!或着服务器端断开客户端又怎么知道呢!该怎么写!如果是多个人一起连接到服务器!该怎么让服务器做个中转站来给客户端之间进行聊天呢!! 
c#数字签名模拟系统
数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#数字签名 c#
英文邮件礼仪:向教授请教学术问题
英文邮件礼仪:向教授请教学术问题   邮件主题 邮件主题(subject)不需要写自己的名字。名字是在邮件系统设置里设定好的,在发件时会替换显示实际地址,所以无需在主题里再写一遍。 [关键内容是要在主题里就写明白是否有推荐人,以及主要是什么事。很多教授只看主题。]   一个好的标题,要能简洁地概括邮件的目的或内容。如果你对教授的某个研究项目感兴趣,就可以用这个研究方向作标题,例如"De
扫盲文件完整性校验——关于散列值和数字签名
转自:http://jmchxy.blog.163.com/blog/static/746082322013121113818518/ 近期有网友在博客中留言,希望俺介绍散列值校验文件的知识。所以俺干脆写一篇”文件完整性校验”的扫盲教程。由于本文是扫盲性质,尽量不涉及太技术化的内容。★什么是”完整性校验”?  所谓的”完整性校验”,顾名思义,就是检查文件是否完整。那么,什么情况下会导致文件不完整捏
C#实现数字签名
C#实现数字签名   [csharp] view plaincopy using System;   using System.Collections.Generic;   using System.Windows.Forms;   using System.Security.Cryptography;      namespace DS
C#如何使用数字签名?
/// /// /// /// /// /// /// private static void EncryptFile(string originalFileName, string encryptedFileName, X509Certificate2 senderCertificate, X509Certificate2 rec
c# 生成数字签名
通过查阅msdn数字证书相关信息,个人觉得程序的证书要最终发挥作用,应当是将我们自己的证书最终要导入到控制台的受信任的根证书颁发机构,不论可执行程序是在何时注册的数字证书(可能是已经注册好放入安装包,也可能是在安装时注册),这时以管理员运行时就会显示出证书的信息,若没有在受信任的根证书颁发机构,将显示发布者未知。   那现在我们要做的也很明确了:   1:首先我们需要生成一个自己的证书
C# 获取文件的数字签名信息
using System.Security.Cryptography.X509Certificates;   X509Certificate cert = X509Certificate.CreateFromSignedFile(filename);   如果是要取文件的'name of signer',在cert.Subject属性中取CN值。       转自:http://b
基于RSA的数字签名和验证C#源码
内含六个DEMO项目. 若要使用公钥系统对消息进行数字签名,发送方先向该消息应用哈希函数以创建消息摘要。 * 然后,发送方用自己的私钥对消息摘要进行加密,以创建发送方的个人签名。在收到消息和 * 签名后,接收方使用发送方的公钥解密该签名,以恢复消息摘要,并使用发送方所用的同一 * 哈希算法对该消息进行哈希运算。如果接收方计算的消息摘要与从发送方收到的消息摘要完 * 全匹配,则接收方可以假定消息在传输中未被更改。请注意,因为发送方的公钥是公共知识, * 所以任何人都可以验证签名。