主頁 > 知識庫 > asp.net 數(shù)字簽名實例代碼

asp.net 數(shù)字簽名實例代碼

熱門標簽:地圖標注多個行程 銅川小型外呼系統(tǒng)運營商 浙江外呼系統(tǒng)怎么安裝 海外地圖標注門市標 云南外呼電銷機器人系統(tǒng) 上海楊浦怎么申請申請400電話 陜西人工外呼系統(tǒng)哪家好 廈門商鋪地圖標注 山西防封卡電銷卡套餐
A給B發(fā)送信息,A會將信息用A的密碼進行加密,然后將加密后的字符串和原文一起發(fā)給B,然后B用B的密碼進行解密,然后判斷解密后的字符串和A發(fā)過來的原文比對是否一致,關鍵問題在于,
A和密碼和B的密碼不一樣,這個才是數(shù)字簽名的精華,A的密碼就是私鑰,B的密碼就是公鑰
具體步驟:
生成一個私鑰和公鑰,A就用私鑰進行加密,因為A的私鑰只有A自己有,所以加密后的字符串就是A的簽名字符串,然后A將這個簽名的字符串和原文發(fā)給B,
B獲取加密的字符串用公鑰進行解密,然后判斷解密后的字符串和原文是否一致,一致說明是A簽名的,否則就不是A簽名的
如果看的還有點迷糊,那么看完下面的例子,在去看上面的文字,估計就明白了
例如:私鑰為S1,公鑰為:G1 A的原文是:123 那么這個流程就是
S1+123 加密生成一個A簽名的字符串:AXXXX
A將AXXXX和123一起發(fā)給B,B用G1將AXXXX進行解密,判斷解密后的字符串是否等于123
相信原理大家都明白了吧。。。明白原理了就好,。呵呵。。。其他的不說了,上代碼。。。代碼是學習別人的。。已經(jīng)過測試。
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 />
原文:nbsp;
asp:TextBox ID="tbxContent" runat="server" TextMode="MultiLine" Height="59px" Width="711px">/asp:TextBox>nbsp;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>
/// 隨機生成密鑰
/// /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());
}
您可能感興趣的文章:
  • ASP.NET web.config中 數(shù)據(jù)庫連接字符串加密解密
  • .NET微信小程序用戶數(shù)據(jù)的簽名驗證和解密代碼

標簽:朔州 信陽 萊蕪 西雙版納 許昌 孝感 自貢 常州

巨人網(wǎng)絡通訊聲明:本文標題《asp.net 數(shù)字簽名實例代碼》,本文關鍵詞  asp.net,數(shù)字簽名,實例,代碼,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《asp.net 數(shù)字簽名實例代碼》相關的同類信息!
  • 本頁收集關于asp.net 數(shù)字簽名實例代碼的相關信息資訊供網(wǎng)民參考!
  • 推薦文章