zoukankan
html css js c++ java
基于RSA的数字签名和验证C#源码
/**/
/*
基于RSA的数字签名和验证C#源码
* (采用字符串作为参数)RSA_Demo3
*
* 夏春涛 Email:xChuntao@163.com
* Blog:
http://bluesky521.cnblogs.com
* 运行环境:.net2.0 framework
*/
/**/
/*
备注:
* 若要使用公钥系统对消息进行数字签名,发送方先向该消息应用哈希函数以创建消息摘要。
* 然后,发送方用自己的私钥对消息摘要进行加密,以创建发送方的个人签名。在收到消息和
* 签名后,接收方使用发送方的公钥解密该签名,以恢复消息摘要,并使用发送方所用的同一
* 哈希算法对该消息进行哈希运算。如果接收方计算的消息摘要与从发送方收到的消息摘要完
* 全匹配,则接收方可以假定消息在传输中未被更改。请注意,因为发送方的公钥是公共知识,
* 所以任何人都可以验证签名。
*/
using
System;
using
System.Security.Cryptography;
using
System.Text;
class
RSACSPSample
{
static
void
Main()
{
try
{
string
str_DataToSign
=
@"
Data to Sign!Data to Sign!Data to Sign!
"
;
Console.WriteLine(
"
原文:
"
+
str_DataToSign);
Console.WriteLine(
"
长度:
"
+
str_DataToSign.Length.ToString());
Console.WriteLine();
RSACryptoServiceProvider RSAalg
=
new
RSACryptoServiceProvider();
string
str_Private_Key
=
Convert.ToBase64String( RSAalg.ExportCspBlob(
true
) );
string
str_Public_Key
=
Convert.ToBase64String( RSAalg.ExportCspBlob(
false
) );
Console.WriteLine(
"
公钥:
"
+
str_Public_Key);
Console.WriteLine();
Console.WriteLine(
"
私钥:
"
+
str_Private_Key);
Console.WriteLine();
string
str_SignedData
=
HashAndSign(str_DataToSign, str_Private_Key);
//
Hash and sign the data.
Console.WriteLine(
"
签名数据:
"
+
str_SignedData);
Console.WriteLine();
if
(VerifySignedHash(str_DataToSign, str_SignedData, str_Public_Key))
{
Console.WriteLine(
"
验证签名OK.
"
);
}
else
{
Console.WriteLine(
"
签名不匹配!
"
);
}
Console.WriteLine();
}
catch
(ArgumentNullException)
{
Console.WriteLine(
"
The data was not signed or verified
"
);
}
}
//
对数据签名
public
static
string
HashAndSign(
string
str_DataToSign,
string
str_Private_Key)
{
ASCIIEncoding ByteConverter
=
new
ASCIIEncoding();
byte
[] DataToSign
=
ByteConverter.GetBytes(str_DataToSign);
try
{
RSACryptoServiceProvider RSAalg
=
new
RSACryptoServiceProvider();
RSAalg.ImportCspBlob( Convert.FromBase64String(str_Private_Key) );
byte
[] signedData
=
RSAalg.SignData(DataToSign,
new
SHA1CryptoServiceProvider());
string
str_SignedData
=
Convert.ToBase64String(signedData);
return
str_SignedData;
}
catch
(CryptographicException e)
{
Console.WriteLine(e.Message);
return
null
;
}
}
//
验证签名
public
static
bool
VerifySignedHash(
string
str_DataToVerify,
string
str_SignedData,
string
str_Public_Key)
{
byte
[] SignedData
=
Convert.FromBase64String(str_SignedData);
ASCIIEncoding ByteConverter
=
new
ASCIIEncoding();
byte
[] DataToVerify
=
ByteConverter.GetBytes(str_DataToVerify);
try
{
RSACryptoServiceProvider RSAalg
=
new
RSACryptoServiceProvider();
RSAalg.ImportCspBlob( Convert.FromBase64String(str_Public_Key) );
return
RSAalg.VerifyData(DataToVerify,
new
SHA1CryptoServiceProvider(), SignedData);
}
catch
(CryptographicException e)
{
Console.WriteLine(e.Message);
return
false
;
}
}
}
附件:
/Files/bluesky521/RSA_Demo.rar
查看全文
相关阅读:
解决在macOS下安装了python却没有pip命令的问题【经验总结】
Mac OS下安装MongoDB以及配置方法总结【笔记】
web上常见的攻击方式及简单的防御方法
Destoon二开必看执行流程
网站入侵注入的几种方法总结【笔记】
命令检测站点是否使用CDN加速
织梦xss通杀所有版本漏洞【学习笔记】
让你知晓内容安全的边界:盘点2017、2018这两年的内容监管
知物由学 | AI网络安全实战:生成对抗网络
人工智能热门图书(深度学习、TensorFlow)免费送!
原文地址:https://www.cnblogs.com/SummerRain/p/1011991.html
最新文章
npm太慢, 淘宝npm镜像使用方法
git 本地分支与远程分支
/etc/fstab 文件挂载配置文件
linux对4T硬盘进行分区
Linux安装npm并打包前端代码
npm 更新版本
XenServer中虚拟机和快照导出与导入
nginx跨域的简单应用
mysql 遍历所有的库并根据表和sql语句备份
win10 同步批处理禁用和启用网卡
热门文章
结构体内存对齐
编辑中常用命令
指针与内存的分配
结构体,共用体,枚举
CSS选择器
VS中代码覆盖问题
C++的string类
CSS初了解
2. getline()和get()
第一章 C++基本认识
Copyright © 2011-2022 走看看