asp.net 數(shù)字簽名實例代碼
更新時間:2012年06月06日 21:23:42 作者:
數(shù)字簽名具體的好處就不說了,看了很多文章,網(wǎng)絡(luò)上各種圖,理解起來可能比較麻煩,在這里簡單說一下原理,減少大家的誤區(qū),純屬個人理解,歡迎糾正
A給B發(fā)送信息,A會將信息用A的密碼進(jìn)行加密,然后將加密后的字符串和原文一起發(fā)給B,然后B用B的密碼進(jìn)行解密,然后判斷解密后的字符串和A發(fā)過來的原文比對是否一致,關(guān)鍵問題在于,
A和密碼和B的密碼不一樣,這個才是數(shù)字簽名的精華,A的密碼就是私鑰,B的密碼就是公鑰
具體步驟:
生成一個私鑰和公鑰,A就用私鑰進(jìn)行加密,因為A的私鑰只有A自己有,所以加密后的字符串就是A的簽名字符串,然后A將這個簽名的字符串和原文發(fā)給B,
B獲取加密的字符串用公鑰進(jìn)行解密,然后判斷解密后的字符串和原文是否一致,一致說明是A簽名的,否則就不是A簽名的
如果看的還有點迷糊,那么看完下面的例子,在去看上面的文字,估計就明白了
例如:私鑰為S1,公鑰為:G1 A的原文是:123 那么這個流程就是
S1+123 加密生成一個A簽名的字符串:AXXXX
A將AXXXX和123一起發(fā)給B,B用G1將AXXXX進(jìn)行解密,判斷解密后的字符串是否等于123
相信原理大家都明白了吧。。。明白原理了就好,。呵呵。。。其他的不說了,上代碼。。。代碼是學(xué)習(xí)別人的。。已經(jīng)過測試。
aspx代碼:
<form id="form1" runat="server">
隨機(jī)生成密鑰:<asp:Button ID="btncreateMY" runat="server" Text="隨機(jī)生成密鑰" 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);
//數(shù)字簽名
tbxSign.Text = BitConverter.ToString(objdsa.SignData(source));
}
/// <summary>
/// 隨機(jī)生成密鑰
/// </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());
}
A和密碼和B的密碼不一樣,這個才是數(shù)字簽名的精華,A的密碼就是私鑰,B的密碼就是公鑰
具體步驟:
生成一個私鑰和公鑰,A就用私鑰進(jìn)行加密,因為A的私鑰只有A自己有,所以加密后的字符串就是A的簽名字符串,然后A將這個簽名的字符串和原文發(fā)給B,
B獲取加密的字符串用公鑰進(jìn)行解密,然后判斷解密后的字符串和原文是否一致,一致說明是A簽名的,否則就不是A簽名的
如果看的還有點迷糊,那么看完下面的例子,在去看上面的文字,估計就明白了
例如:私鑰為S1,公鑰為:G1 A的原文是:123 那么這個流程就是
S1+123 加密生成一個A簽名的字符串:AXXXX
A將AXXXX和123一起發(fā)給B,B用G1將AXXXX進(jìn)行解密,判斷解密后的字符串是否等于123
相信原理大家都明白了吧。。。明白原理了就好,。呵呵。。。其他的不說了,上代碼。。。代碼是學(xué)習(xí)別人的。。已經(jīng)過測試。
aspx代碼:
復(fù)制代碼 代碼如下:
<form id="form1" runat="server">
隨機(jī)生成密鑰:<asp:Button ID="btncreateMY" runat="server" Text="隨機(jī)生成密鑰" 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代碼
復(fù)制代碼 代碼如下:
/// <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);
//數(shù)字簽名
tbxSign.Text = BitConverter.ToString(objdsa.SignData(source));
}
/// <summary>
/// 隨機(jī)生成密鑰
/// </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());
}
相關(guān)文章
asp.net mvc4 mysql制作簡單分頁組件(部分視圖)
這篇文章主要介紹了asp.net mvc4 mysql制作簡單分頁組件,附部分視圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10
ASP.NET數(shù)據(jù)綁定的記憶碎片實現(xiàn)代碼
ASP.NET數(shù)據(jù)綁定的記憶碎片實現(xiàn)代碼,需要的朋友可以參考下2012-10-10
ASP.NET實現(xiàn)可以縮放和旋轉(zhuǎn)的圖片預(yù)覽頁效果
本文詳細(xì)介紹了如何在ASP.NET?WebForms中實現(xiàn)一個功能豐富的圖片預(yù)覽頁面,通過結(jié)合HTML、CSS和JavaScript,用戶可以方便地對圖片進(jìn)行放大、縮小以及旋轉(zhuǎn)操作,感興趣的朋友跟隨小編一起看看吧2024-08-08
Asp.Net?Core配置多環(huán)境log4net配置文件的全過程
在.NET世界中有非常多的日志框架,然而log4net是目前為止最流行的一款日志框架,下面這篇文章主要給大家介紹了關(guān)于Asp.Net?Core配置多環(huán)境log4net配置文件的相關(guān)資料,需要的朋友可以參考下2022-04-04
ASP.NET使用SignalR2實現(xiàn)服務(wù)器廣播
這篇文章介紹了ASP.NET使用SignalR2實現(xiàn)服務(wù)器廣播的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05
asp.net 網(wǎng)頁動態(tài)查詢條件的實現(xiàn)
最近有一個需求,會在 mongodb 中插入各種類型的數(shù)據(jù),算是記錄業(yè)務(wù)日志的數(shù)據(jù)庫吧。因為業(yè)務(wù)對象類型都不同,所以插入的數(shù)據(jù)格式也完全不同2012-10-10
ASP.NET設(shè)計網(wǎng)絡(luò)硬盤之文件夾實現(xiàn)
ASP.NET設(shè)計網(wǎng)絡(luò)硬盤之文件夾實現(xiàn)...2006-09-09
asp.net 基于forms驗證的目錄角色權(quán)限的實現(xiàn)
一個系統(tǒng)中經(jīng)常有多種身份的用戶,往往要根據(jù)其身份來控制目錄的訪問權(quán)限。asp.net提供了forms驗證,能夠輕易的在配置文件中設(shè)置用戶對目錄的訪問權(quán)限.2009-11-11

