1 基本概念
数字签名是一种加密技术,用于验证信息来源的身份和数据的完整性。
就是对一个东西签上自己的名;收到的人可以验证这东西是你发的;这里是用数字的方式;
对字符串也可以签名,签名以后,还是一个字符串,不过是经过签名的字符串。
密钥有公钥和私钥; 公钥是公开的,人人都知道;私钥是自己的,只有自己知道;
签上自己的名,那肯定用自己的私钥;
C#代码看一下;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Security.Cryptography;namespace rsademo
{public partial class Form1 : Form{private string publicKey;private string privateKey;public Form1(){InitializeComponent();}private void Form1_Load(object sender, EventArgs e){using (var rsa = new RSACryptoServiceProvider()){publicKey = rsa.ToXmlString(false); // 公钥privateKey = rsa.ToXmlString(true); // 私钥}}public static string SignData(string data, string privateKey){using (var rsa = new RSACryptoServiceProvider()){rsa.FromXmlString(privateKey);byte[] dataBytes = Encoding.UTF8.GetBytes(data);byte[] signatureBytes = rsa.SignData(dataBytes, CryptoConfig.MapNameToOID("SHA1"));return Convert.ToBase64String(signatureBytes);}}private void button1_Click(object sender, EventArgs e){textBox2.Text = SignData(textBox1.Text, privateKey);}}
}
首先new一个RSA加密服务提供者对象;
然后可以生成公钥和私钥;
写一个签名函数,需要的参数是待签名的字符串、私钥;
第一个文本框是原来的字符串,第二个文本框是经过数字签名的字符串;