服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服务器之家 - 编程语言 - ASP.NET教程 - asp.net 数字签名实例代码

asp.net 数字签名实例代码

2019-10-06 11:10asp.net代码网 ASP.NET教程

数字签名具体的好处就不说了,看了很多文章,网络上各种图,理解起来可能比较麻烦,在这里简单说一下原理,减少大家的误区,纯属个人理解,欢迎纠正

A给B发送信息,A会将信息用A的密码进行加密,然后将加密后的字符串和原文一起发给B,然后B用B的密码进行解密,然后判断解密后的字符串和A发过来的原文比对是否一致,关键问题在于, 
A和密码和B的密码不一样,这个才是数字签名的精华,A的密码就是私钥,B的密码就是公钥 
具体步骤: 
生成一个私钥和公钥,A就用私钥进行加密,因为A的私钥只有A自己有,所以加密后的字符串就是A的签名字符串,然后A将这个签名的字符串和原文发给B, 
B获取加密的字符串用公钥进行解密,然后判断解密后的字符串和原文是否一致,一致说明是A签名的,否则就不是A签名的 
如果看的还有点迷糊,那么看完下面的例子,在去看上面的文字,估计就明白了 
例如:私钥为S1,公钥为:G1 A的原文是:123 那么这个流程就是 
S1+123 加密生成一个A签名的字符串:AXXXX 
A将AXXXX和123一起发给B,B用G1将AXXXX进行解密,判断解密后的字符串是否等于123 
相信原理大家都明白了吧。。。明白原理了就好,。呵呵。。。其他的不说了,上代码。。。代码是学习别人的。。已经过测试。 
aspx代码: 

复制代码代码如下:


<form id="form1" runat="server"> 
随机生成密钥:<asp:Button ID="btncreateMY" runat="server" Text="随机生成密钥" OnClick="btncreateMY_Click" /><br /> 
公钥:<asp:TextBox ID="tbxcreateMY_publicKey" runat="server" TextMode="MultiLine" Height="59px" ReadOnly="True" Width="711px"></asp:TextBox><br /> 
私钥:<asp:TextBox ID="tbxcreateMY_key" runat="server" TextMode="MultiLine" Height="59px" ReadOnly="True" Width="710px"></asp:TextBox><br /><hr /> 
<br /> 
生成签名:<br /> 
原文:  
<asp:TextBox ID="tbxContent" runat="server" TextMode="MultiLine" Height="59px" Width="711px"></asp:TextBox> <br /> 
私钥: 
<asp:TextBox ID="tbxKey" runat="server" TextMode="MultiLine" Height="59px" Width="711px"></asp:TextBox><br /> 
签名: 
<asp:TextBox ID="tbxSign" runat="server" TextMode="MultiLine" Height="59px" ReadOnly="True" Width="711px"></asp:TextBox> 
<br /> 
<asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="生成签名" /> 
<br /> 
<br /><hr /> 
<br /> 
验证签名:<br /> 
原文:<asp:TextBox ID="tbxContentYZ" runat="server" TextMode="MultiLine" Height="59px" Width="711px"></asp:TextBox><br /> 
公钥:<asp:TextBox ID="tbxPublickeyYZ" runat="server" TextMode="MultiLine" Height="59px" Width="711px"></asp:TextBox><br /> 
签名:<asp:TextBox ID="tbxSignYZ" runat="server" TextMode="MultiLine" Height="59px" Width="711px"></asp:TextBox> 
<br /> 
<asp:Button ID="Button3" runat="server" OnClick="Button3_Click" Text="验证签名" /> 
</form> 


CS代码 

复制代码代码如下:


/// <summary> 
/// 生成签名 
/// </summary> 
/// <param name="sender"></param> 
/// <param name="e"></param> 
protected void Button1_Click(object sender, EventArgs e) 

DSACryptoServiceProvider objdsa = new DSACryptoServiceProvider(); 
objdsa.FromXmlString(tbxKey.Text); 
byte[] source = System.Text.UTF8Encoding.UTF8.GetBytes(tbxContent.Text); 
//数字签名 
tbxSign.Text = BitConverter.ToString(objdsa.SignData(source)); 

/// <summary> 
/// 随机生成密钥 
/// </summary> 
/// <param name="sender"></param> 
/// <param name="e"></param> 
protected void btncreateMY_Click(object sender, EventArgs e) 

DSACryptoServiceProvider objdsa = new DSACryptoServiceProvider(); 
tbxcreateMY_publicKey.Text = objdsa.ToXmlString(false); 
tbxcreateMY_key.Text = objdsa.ToXmlString(true); 

/// <summary> 
/// 验证签名 
/// </summary> 
/// <param name="sender"></param> 
/// <param name="e"></param> 
protected void Button3_Click(object sender, EventArgs e) 

DSACryptoServiceProvider objdsa = new DSACryptoServiceProvider(); 
byte[] fileHashValue = new SHA1CryptoServiceProvider().ComputeHash(System.Text.UTF8Encoding.UTF8.GetBytes(tbxContentYZ.Text)); 
string[] strSplit = tbxSignYZ.Text.Split('-'); 
byte[] SignedHash = new byte[strSplit.Length]; 
for (int i = 0; i < strSplit.Length; i++) 
SignedHash[i] = byte.Parse(strSplit[i], System.Globalization.NumberStyles.AllowHexSpecifier); 
objdsa.FromXmlString(tbxPublickeyYZ.Text); 
bool ret = objdsa.VerifySignature(fileHashValue, SignedHash); 
Response.Write(ret.ToString()); 
// Qcd.Core.Web.Messages.ShowDialog(ret.ToString()); 

延伸 · 阅读

精彩推荐