当前位置: 首页 > news >正文

[C#数据加密]——MD5、SHA、AES、RSA

一、C#数据加密介绍


数据加密是信息安全领域的一个重要组成部分,它用于保护数据不被未授权访问。以下是一些常见的加密算法和方法:

1、MD5 (Message Digest Algorithm 5):

  • 一种广泛使用的哈希函数,可以产生128位的哈希值。
  • 通常用于验证文件完整性,但因为其易受到碰撞攻击,不推荐用于需要高安全性的场合。

 

2、SHA (Secure Hash Algorithm):

  • 一系列密码散列函数,包括SHA-1、SHA-2(如SHA-256、SHA-512)和SHA-3。
  • 比MD5更安全,能产生更长的哈希值,用于确保数据的完整性和验证。

3、AES (Advanced Encryption Standard):

  • 一种对称密钥加密标准,使用128位、192位或256位的密钥。
  • 非常安全,广泛用于保护数据传输和存储。

4、RSA:

  • 一种非对称加密算法,基于大整数分解的困难性。
  • 通常用于安全的数据传输,数字签名和密钥交换。
  • RSA算法使用两个密钥:一个公钥用于加密,一个私钥用于解密。

二、C#数据加密示例

1、可以使用System.Security.Cryptography命名空间中的MD5类来实现MD5哈希算法。以下是一个简单的C#代码示例,演示如何使用MD5对字符串进行哈希计算:

using System;
using System.Security.Cryptography;
using System.Text;public class MD5Example
{public static void Main(string[] args){// 待加密的原始字符串string originalString = "Hello, World!";// 将字符串转换为字节数组byte[] inputBytes = Encoding.UTF8.GetBytes(originalString);// 创建MD5哈希算法实例using (MD5 md5 = MD5.Create()){// 计算哈希值byte[] hashBytes = md5.ComputeHash(inputBytes);// 将哈希值转换为十六进制字符串StringBuilder hashStringBuilder = new StringBuilder();for (int i = 0; i < hashBytes.Length; i++){hashStringBuilder.Append(hashBytes[i].ToString("x2"));}// 输出MD5哈希值Console.WriteLine("MD5 Hash: " + hashStringBuilder.ToString());}}
}

2、可以使用System.Security.Cryptography命名空间中的SHA256类来实现SHA-256哈希算法。以下是一个C#代码示例,演示如何使用SHA-256对字符串进行哈希计算:

using System;
using System.Security.Cryptography;
using System.Text;public class SHA256Example
{public static void Main(string[] args){// 待加密的原始字符串string originalString = "Hello, World!";// 将字符串转换为字节数组byte[] inputBytes = Encoding.UTF8.GetBytes(originalString);// 创建SHA256哈希算法实例using (SHA256 sha256 = SHA256.Create()){// 计算哈希值byte[] hashBytes = sha256.ComputeHash(inputBytes);// 将哈希值转换为十六进制字符串StringBuilder hashStringBuilder = new StringBuilder();for (int i = 0; i < hashBytes.Length; i++){hashStringBuilder.Append(hashBytes[i].ToString("x2"));}// 输出SHA-256哈希值Console.WriteLine("SHA-256 Hash: " + hashStringBuilder.ToString());}}
}

3、使用AES加密数据可以通过System.Security.Cryptography命名空间中的Aes类来实现。以下是一个使用AES加密算法的示例代码,包括密钥生成、加密和解密过程:

using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;public class AESExample
{public static void Main(string[] args){// 待加密的数据string originalData = "Hello, World!";byte[] dataToEncrypt = Encoding.UTF8.GetBytes(originalData);// 使用256位密钥using (Aes aes = Aes.Create()){aes.Key = Encoding.UTF8.GetBytes("your-32-byte-long-key-here!"); // 密钥长度可以是16, 24, 32字节aes.IV = Encoding.UTF8.GetBytes("your-16-byte-long-iv-here!");   // IV长度必须和块大小相同,对于AES是16字节// 准备内存流以用于加密using (MemoryStream memoryStream = new MemoryStream()){// 将加密流包装在内存流中using (CryptoStream cryptoStream = new CryptoStream(memoryStream, aes.CreateEncryptor(), CryptoStreamMode.Write)){// 写入数据并加密cryptoStream.Write(dataToEncrypt, 0, dataToEncrypt.Length);cryptoStream.FlushFinalBlock(); // 必须调用以完成加密过程}// 转换加密后的数据为16进制字符串string encryptedData = Convert.ToBase64String(memoryStream.ToArray());Console.WriteLine("Encrypted Data: " + encryptedData);// 为了演示解密,我们在这里也提供解密的代码// 准备内存流以用于解密using (MemoryStream decryptMemoryStream = new MemoryStream(Convert.FromBase64String(encryptedData))){// 将解密流包装在内存流中using (CryptoStream decryptCryptoStream = new CryptoStream(decryptMemoryStream, aes.CreateDecryptor(), CryptoStreamMode.Read)){// 读取解密后的数据byte[] decryptedData = new byte[dataToEncrypt.Length];int decryptedCount = decryptCryptoStream.Read(decryptedData, 0, decryptedData.Length);// 转换解密后的数据为字符串string decryptedDataString = Encoding.UTF8.GetString(decryptedData, 0, decryptedCount);Console.WriteLine("Decrypted Data: " + decryptedDataString);}}}}}
}

4、使用RSA加密和解密可以通过System.Security.Cryptography命名空间中的RSA类来实现。以下是一个C#代码示例,演示了如何生成RSA密钥对、使用公钥加密数据以及使用私钥解密数据:

using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;public class RSAExample
{public static void Main(string[] args){// 生成RSA密钥对using (var rsa = new RSACryptoServiceProvider(2048)){// 获取公钥和私钥byte[] publicKey = rsa.ToXmlString(false).DecodeFromXmlString().GetRSAPublicKey();byte[] privateKey = rsa.ToXmlString(true).DecodeFromXmlString().GetRSAPrivateKey();// 待加密的原始数据string originalData = "Hello, World!";byte[] dataToEncrypt = Encoding.UTF8.GetBytes(originalData);// 使用公钥加密数据byte[] encryptedData = rsa.Encrypt(dataToEncrypt, true);// 显示加密后的数据Console.WriteLine("Encrypted Data: " + Convert.ToBase64String(encryptedData));// 使用私钥解密数据byte[] decryptedData = rsa.Decrypt(encryptedData, true);// 显示解密后的数据string decryptedDataString = Encoding.UTF8.GetString(decryptedData);Console.WriteLine("Decrypted Data: " + decryptedDataString);// 保存和加载密钥对SaveRSAKey(rsa, "rsaKeys.xml");using (var rsaFromStorage = LoadRSAKey("rsaKeys.xml")){// 可以继续使用加载的密钥进行加密或解密操作}}}private static void SaveRSAKey(RSACryptoServiceProvider rsa, string filename){// 将私钥保存到文件File.WriteAllText(filename, rsa.ToXmlString(true));}private static RSACryptoServiceProvider LoadRSAKey(string filename){// 从文件加载私钥string xml = File.ReadAllText(filename);return new RSACryptoServiceProvider().FromXmlString(xml);}
}public static class RSAExtensions
{public static byte[] GetRSAPublicKey(this RSAParameters rsaParams){byte[] publicKey = new byte[rsaParams.Modulus.Length + rsaParams.Exponent.Length];Array.Copy(rsaParams.Modulus, 0, publicKey, 0, rsaParams.Modulus.Length);Array.Copy(rsaParams.Exponent, 0, publicKey, rsaParams.Modulus.Length, rsaParams.Exponent.Length);return publicKey;}public static byte[] GetRSAPrivateKey(this RSAParameters rsaParams){byte[] privateKey = new byte[rsaParams.Modulus.Length + rsaParams.Exponent.Length + rsaParams.D.Length + rsaParams.P.Length + rsaParams.Q.Length];Array.Copy(rsaParams.Modulus, 0, privateKey, 0, rsaParams.Modulus.Length);Array.Copy(rsaParams.Exponent, 0, privateKey, rsaParams.Modulus.Length, rsaParams.Exponent.Length);Array.Copy(rsaParams.D, 0, privateKey, rsaParams.Modulus.Length + rsaParams.Exponent.Length, rsaParams.D.Length);Array.Copy(rsaParams.P, 0, privateKey, rsaParams.Modulus.Length + rsaParams.Exponent.Length + rsaParams.D.Length, rsaParams.P.Length);Array.Copy(rsaParams.Q, 0, privateKey, rsaParams.Modulus.Length + rsaParams.Exponent.Length + rsaParams.D.Length + rsaParams.P.Length, rsaParams.Q.Length);return privateKey;}public static string DecodeFromXmlString(this byte[] xmlBytes){return Encoding.UTF8.GetString(xmlBytes);}
}

三、数据加密完结

        每种加密方法都有其特定的用途和安全级别。选择哪种加密方法取决于你的具体需求,比如需要保护的数据类型、安全要求、性能考虑等。在实际应用中,通常需要结合使用多种加密技术来达到最佳的安全效果。

相关文章:

[C#数据加密]——MD5、SHA、AES、RSA

一、C#数据加密介绍 数据加密是信息安全领域的一个重要组成部分&#xff0c;它用于保护数据不被未授权访问。以下是一些常见的加密算法和方法&#xff1a; 1、MD5 (Message Digest Algorithm 5): 一种广泛使用的哈希函数&#xff0c;可以产生128位的哈希值。通常用于验证文件完…...

QT不阻塞UI的方式

方法1&#xff1a;QtConcurrent #include <QtConcurrent> #include <QFuture> #include <QFutureWatcher> #include <QDebug>void longRunningTask() {// 模拟耗时操作QThread::sleep(5); }void startTask() {QFuture<void> future QtConcurre…...

鸿蒙HarmonyOS开发:常用布局及实用技巧

文章目录 一、概述二、盒子模型三、线性布局&#xff08;Column/Row&#xff09;1、space属性2、justifyContent属性3、alignItems属性 四、实用技巧1、Blank组件的使用2、layoutWeight属性的使用 一、概述 布局是指对页面组件进行排列和定位的过程&#xff0c;其目的是有效地…...

【解答】洛必达法则的使用条件及常见错误,洛必达法则的适用条件,常见的易错点,2022数一第一题例题

目录 洛必达法则的使用条件及常见错误 洛必达法则的适用条件 常见的易错点 举例说明&#xff08;见D选项&#xff09; 总结 &#x1f308; 嗨&#xff0c;我是命运之光&#xff01; &#x1f30c; 2024&#xff0c;每日百字&#xff0c;记录时光&#xff0c;感谢有你&…...

使用Python下载飞书共享表格数据教程

写在前面 随着企业协作办公软件的流行&#xff0c;飞书以其高效的协作能力和便捷的共享功能&#xff0c;成为了许多公司必备的工具之一。在日常工作中&#xff0c;我们经常需要从飞书中下载共享的表格数据进行分析。本文将详细介绍如何使用Python下载飞书共享表格数据。 前置…...

【C++】protobuf的简单使用(通讯录例子)

protobuf的简单使用&#xff08;通讯录例子&#xff09; .proto文件的编写保留字段字段唯一编号protobuf的类型enum类型Any类型oneof类型map类型完整通讯录代码.proto文件write文件read文件运行结果 .proto文件的编写 syntax用于指定protobuf的语法&#xff1b;package当.prot…...

Apple 智能基础语言模型

Introducing Apple’s On-Device and Server Foundation Models technical details June 10, 2024 在2024年的全球开发者大会上&#xff0c;苹果推出了Apple Intelligence&#xff0c;这是一个深度集成到iOS 18、iPadOS 18和macOS Sequoia中的个人智能系统。Apple Intelligen…...

GreptimeDB融资数百万美元; Oracle提供免费长期MySQL; 谷歌大模型支持云数据库问题洞察

重要更新 1. 开源时序数据库 GreptimeDB宣布完成数百万美元的新一轮融资。GreptimeDB是一款Rust 语言编写的时序数据库&#xff0c;具有分布式&#xff0c;开源&#xff0c;云原生&#xff0c;兼容性强等特点&#xff0c;帮助企业实时读写、处理和分析时序数据的同时&#xff0…...

Java中的抽象类与接口

1. 抽象类 1.1 抽象类概念 在面向对象的概念中&#xff0c;所有的对象都是通过类来描绘的&#xff0c;但是反过来&#xff0c;并不是所有的类都是用来描绘对象的&#xff0c; 如果一个类中没有包含足够的信息来描绘一个具体的对象&#xff0c;这样的类就是抽象类。 比如&…...

云计算概念以及与云服务的区别

目录 1.云的概念 1.1 什么是云&#xff1f; 1.2 云计算的类型 1.3 云计算的服务模式 1.4 云计算的优势 2.云计算和云服务的区别 2.1 定义 2.2 范围 2.3 角色 2.5 举例 2.6使用者 3.总结 1.云的概念 1.1 什么是云&#xff1f; “云”在计算机科学和信息技术领域通常…...

Netty技术全解析:LengthFieldBaseFrameDecoder类深度解析

❃博主首页 &#xff1a; 「码到三十五」 &#xff0c;同名公众号 :「码到三十五」&#xff0c;wx号 : 「liwu0213」 ☠博主专栏 &#xff1a; <mysql高手> <elasticsearch高手> <源码解读> <java核心> <面试攻关> ♝博主的话 &#xff1a…...

深入InnoDB核心:揭秘B+树在数据库索引中的高效应用

目录 一、索引页与数据行的紧密关联 &#xff08;一&#xff09;数据页的双向链表结构 &#xff08;二&#xff09;记录行的单向链表结构 二、未创建索引情况 &#xff08;一&#xff09;无索引下的单页查找过程 以主键为搜索条件 以非主键列为搜索条件 &#xff08;二…...

c++(面向对象的性质:抽象,封装,继承,多态)

ctrla全选&#xff0c;ctrli对齐 ctrl/ 一起注释 ctrlz 退回上一步 一些基础的内容&#xff1a; cout&#xff1a;输出流对象 cin&#xff1a;输入流对象 输入一个i和一个j&#xff0c;然后输出ij的和&#xff1a; 值不变的原因&#xff1a; 值传递&#xff0c;a和i是…...

java基础学习笔记1

Java编程规范 命名风格 1. 【强制】代码中的命名均不能以下划线或美元符号开始&#xff0c;也不能以下划线或美元符号结束。 反例&#xff1a;_name / __name / $name / name_ / name$ / name__ 2. 【强制】代码中的命名严禁使用拼音与英文混合的方式&#xff0c;更不允许直…...

[VBA]使用VBA在Excel中 操作 形状shape 对象

excel已关闭地图插件,对于想做 地图可视化 的,用形状来操作是一种办法,就是要自行找到合适的 地图形状,修改形状颜色等就可以用于 可视化展示不同省市销量、人口等数据。 引言 在Excel中,通过VBA(Visual Basic for Applications)可以极大地增强数据可视化和报告自动化…...

Apache POI 实现 Excel 表格下载

这里以苍穹外卖中数据导出功能为例&#xff0c;记录下 Apache POI 导出 Excel 表格的过程。 首先在 pom.xml 中导入相关依赖 <!-- poi 用于操作 excel 表格--> <dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId&…...

大华嵌入式面试题大全及参考答案(2万字长文)

目录 在C语言中,static 关键字有哪些主要用途? static 修饰的全局变量与普通全局变量有什么区别? 为什么要在嵌入式系统中使用 static 修饰函数? 虚函数与纯虚函数了解么? strcpy 给你加结束符吗,还是要自己加? select 的作用是什么,它和 epoll 的区别? map 与…...

C语言——查漏补缺

前言 本篇博客主要记录一些C语言的遗漏点&#xff0c;完成查漏补缺的工作&#xff0c;如果读者感兴趣&#xff0c;可以看看下面的内容。都是一些小点&#xff0c;下面进入正文部分。 1. 字符汇聚 编写代码&#xff0c;演示多个字符从两端移动&#xff0c;向中间汇聚 #inclu…...

Python | Leetcode Python题解之第328题奇偶链表

题目&#xff1a; 题解&#xff1a; class Solution:def oddEvenList(self, head: ListNode) -> ListNode:if not head:return headevenHead head.nextodd, even head, evenHeadwhile even and even.next:odd.next even.nextodd odd.nexteven.next odd.nexteven even…...

吉瑞外卖笔记

1.项目整体搭建 这里用到的是springboot3mybatisplus 1.1数据库搭建 整体表搭建&#xff0c;这里我是直接用的老师给的数据库 1.2maven项目搭建 依赖 这两个jar包第一次用&#xff0c;记录一下 fastjson json处理&#xff0c;可将对象转化为json形式 可将对象中的属性…...

智慧医疗能源事业线深度画像分析(上)

引言 医疗行业作为现代社会的关键基础设施,其能源消耗与环境影响正日益受到关注。随着全球"双碳"目标的推进和可持续发展理念的深入,智慧医疗能源事业线应运而生,致力于通过创新技术与管理方案,重构医疗领域的能源使用模式。这一事业线融合了能源管理、可持续发…...

论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(二)

HoST框架核心实现方法详解 - 论文深度解读(第二部分) 《Learning Humanoid Standing-up Control across Diverse Postures》 系列文章: 论文深度解读 + 算法与代码分析(二) 作者机构: 上海AI Lab, 上海交通大学, 香港大学, 浙江大学, 香港中文大学 论文主题: 人形机器人…...

MySQL 隔离级别:脏读、幻读及不可重复读的原理与示例

一、MySQL 隔离级别 MySQL 提供了四种隔离级别,用于控制事务之间的并发访问以及数据的可见性,不同隔离级别对脏读、幻读、不可重复读这几种并发数据问题有着不同的处理方式,具体如下: 隔离级别脏读不可重复读幻读性能特点及锁机制读未提交(READ UNCOMMITTED)允许出现允许…...

(二)TensorRT-LLM | 模型导出(v0.20.0rc3)

0. 概述 上一节 对安装和使用有个基本介绍。根据这个 issue 的描述&#xff0c;后续 TensorRT-LLM 团队可能更专注于更新和维护 pytorch backend。但 tensorrt backend 作为先前一直开发的工作&#xff0c;其中包含了大量可以学习的地方。本文主要看看它导出模型的部分&#x…...

【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)

服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...

基于当前项目通过npm包形式暴露公共组件

1.package.sjon文件配置 其中xh-flowable就是暴露出去的npm包名 2.创建tpyes文件夹&#xff0c;并新增内容 3.创建package文件夹...

MVC 数据库

MVC 数据库 引言 在软件开发领域,Model-View-Controller(MVC)是一种流行的软件架构模式,它将应用程序分为三个核心组件:模型(Model)、视图(View)和控制器(Controller)。这种模式有助于提高代码的可维护性和可扩展性。本文将深入探讨MVC架构与数据库之间的关系,以…...

论文浅尝 | 基于判别指令微调生成式大语言模型的知识图谱补全方法(ISWC2024)

笔记整理&#xff1a;刘治强&#xff0c;浙江大学硕士生&#xff0c;研究方向为知识图谱表示学习&#xff0c;大语言模型 论文链接&#xff1a;http://arxiv.org/abs/2407.16127 发表会议&#xff1a;ISWC 2024 1. 动机 传统的知识图谱补全&#xff08;KGC&#xff09;模型通过…...

九天毕昇深度学习平台 | 如何安装库?

pip install 库名 -i https://pypi.tuna.tsinghua.edu.cn/simple --user 举个例子&#xff1a; 报错 ModuleNotFoundError: No module named torch 那么我需要安装 torch pip install torch -i https://pypi.tuna.tsinghua.edu.cn/simple --user pip install 库名&#x…...

【Go语言基础【13】】函数、闭包、方法

文章目录 零、概述一、函数基础1、函数基础概念2、参数传递机制3、返回值特性3.1. 多返回值3.2. 命名返回值3.3. 错误处理 二、函数类型与高阶函数1. 函数类型定义2. 高阶函数&#xff08;函数作为参数、返回值&#xff09; 三、匿名函数与闭包1. 匿名函数&#xff08;Lambda函…...