数字签名学习

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加密服务提供者对象;
然后可以生成公钥和私钥;
写一个签名函数,需要的参数是待签名的字符串、私钥;

第一个文本框是原来的字符串,第二个文本框是经过数字签名的字符串; 

相关推荐

  1. 密码学 | 数字签名方法:Schnorr 签名

    2024-04-29 07:10:02       13 阅读
  2. 数字签名介绍

    2024-04-29 07:10:02       39 阅读
  3. 密码学——数字签名

    2024-04-29 07:10:02       20 阅读
  4. Excel数字签名技术总结

    2024-04-29 07:10:02       19 阅读
  5. 【ARM 安全系列介绍 3.1 -- 数字签名算法 ECDSA】

    2024-04-29 07:10:02       34 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-29 07:10:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-29 07:10:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-29 07:10:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-29 07:10:02       20 阅读

热门阅读

  1. 【Vue3】watchEffect的使用

    2024-04-29 07:10:02       12 阅读
  2. STL第三弹---函数对象

    2024-04-29 07:10:02       17 阅读
  3. C#发票查验开发示例、发票识别开发文档

    2024-04-29 07:10:02       15 阅读
  4. asp.net表单上传文件

    2024-04-29 07:10:02       13 阅读
  5. 在cocos2d-x中编译/调试curl库

    2024-04-29 07:10:02       13 阅读
  6. 每天一个数据分析题(二百九十七)

    2024-04-29 07:10:02       17 阅读
  7. 【MySQL】1.安装与配置

    2024-04-29 07:10:02       11 阅读
  8. 代谢组数据分析六:其他分析

    2024-04-29 07:10:02       13 阅读
  9. python代码实现KNN对鸢尾花的分类

    2024-04-29 07:10:02       13 阅读
  10. ROS常用命令详解

    2024-04-29 07:10:02       12 阅读