asp数字签名实例代码
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">
param name随机⽣成密钥:<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="71
1px"></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());
}

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。