.Net中对称加密的实现

常见对称加密算法及优缺点

1. DES(Data Encryption Standard)

  • 优点:是最早被广泛应用的加密算法,算法公开,实现简单,效率较高。
  • 缺点:密钥长度较短(56 位),在现代计算能力下,安全性较低,容易被暴力破解。

2. 3DES(Triple DES)

  • 优点:在 DES 的基础上进行了改进,通过多次使用 DES 算法,增加了密钥长度,提高了安全性。
  • 缺点:由于多次使用 DES 算法,加密和解密速度相对较慢。

3. AES(Advanced Encryption Standard)

  • 优点:是目前应用最广泛的对称加密算法,密钥长度可选(128 位、192 位、256 位),安全性高,加密和解密速度快。
  • 缺点:相对来说,算法复杂度较高,实现难度较大。

示例代码

using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;class SymmetricEncryption
{// DES 加密public static string DESEncrypt(string plainText, string key){using (DESCryptoServiceProvider des = new DESCryptoServiceProvider()){byte[] inputBytes = Encoding.UTF8.GetBytes(plainText);byte[] keyBytes = Encoding.UTF8.GetBytes(key);byte[] encryptedBytes;using (MemoryStream ms = new MemoryStream()){using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(keyBytes, keyBytes), CryptoStreamMode.Write)){cs.Write(inputBytes, 0, inputBytes.Length);cs.FlushFinalBlock();encryptedBytes = ms.ToArray();}}return Convert.ToBase64String(encryptedBytes);}}// DES 解密public static string DESDecrypt(string cipherText, string key){using (DESCryptoServiceProvider des = new DESCryptoServiceProvider()){byte[] inputBytes = Convert.FromBase64String(cipherText);byte[] keyBytes = Encoding.UTF8.GetBytes(key);byte[] decryptedBytes;using (MemoryStream ms = new MemoryStream()){using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(keyBytes, keyBytes), CryptoStreamMode.Write)){cs.Write(inputBytes, 0, inputBytes.Length);cs.FlushFinalBlock();decryptedBytes = ms.ToArray();}}return Encoding.UTF8.GetString(decryptedBytes);}}// 3DES 加密public static string TripleDESEncrypt(string plainText, string key){using (TripleDESCryptoServiceProvider tripleDes = new TripleDESCryptoServiceProvider()){byte[] inputBytes = Encoding.UTF8.GetBytes(plainText);byte[] keyBytes = Encoding.UTF8.GetBytes(key);byte[] encryptedBytes;using (MemoryStream ms = new MemoryStream()){using (CryptoStream cs = new CryptoStream(ms, tripleDes.CreateEncryptor(keyBytes, keyBytes), CryptoStreamMode.Write)){cs.Write(inputBytes, 0, inputBytes.Length);cs.FlushFinalBlock();encryptedBytes = ms.ToArray();}}return Convert.ToBase64String(encryptedBytes);}}// 3DES 解密public static string TripleDESDecrypt(string cipherText, string key){using (TripleDESCryptoServiceProvider tripleDes = new TripleDESCryptoServiceProvider()){byte[] inputBytes = Convert.FromBase64String(cipherText);byte[] keyBytes = Encoding.UTF8.GetBytes(key);byte[] decryptedBytes;using (MemoryStream ms = new MemoryStream()){using (CryptoStream cs = new CryptoStream(ms, tripleDes.CreateDecryptor(keyBytes, keyBytes), CryptoStreamMode.Write)){cs.Write(inputBytes, 0, inputBytes.Length);cs.FlushFinalBlock();decryptedBytes = ms.ToArray();}}return Encoding.UTF8.GetString(decryptedBytes);}}// AES 加密public static string AESEncrypt(string plainText, string key){using (Aes aesAlg = Aes.Create()){byte[] inputBytes = Encoding.UTF8.GetBytes(plainText);byte[] keyBytes = Encoding.UTF8.GetBytes(key);aesAlg.Key = keyBytes;aesAlg.GenerateIV();byte[] encryptedBytes;using (MemoryStream ms = new MemoryStream()){using (CryptoStream cs = new CryptoStream(ms, aesAlg.CreateEncryptor(aesAlg.Key, aesAlg.IV), CryptoStreamMode.Write)){cs.Write(inputBytes, 0, inputBytes.Length);cs.FlushFinalBlock();encryptedBytes = ms.ToArray();}byte[] combinedBytes = new byte[aesAlg.IV.Length + encryptedBytes.Length];Array.Copy(aesAlg.IV, 0, combinedBytes, 0, aesAlg.IV.Length);Array.Copy(encryptedBytes, 0, combinedBytes, aesAlg.IV.Length, encryptedBytes.Length);return Convert.ToBase64String(combinedBytes);}}}// AES 解密public static string AESDecrypt(string cipherText, string key){byte[] combinedBytes = Convert.FromBase64String(cipherText);byte[] iv = new byte[16];byte[] encryptedBytes = new byte[combinedBytes.Length - iv.Length];Array.Copy(combinedBytes, 0, iv, 0, iv.Length);Array.Copy(combinedBytes, iv.Length, encryptedBytes, 0, encryptedBytes.Length);using (Aes aesAlg = Aes.Create()){byte[] keyBytes = Encoding.UTF8.GetBytes(key);aesAlg.Key = keyBytes;aesAlg.IV = iv;byte[] decryptedBytes;using (MemoryStream ms = new MemoryStream()){using (CryptoStream cs = new CryptoStream(ms, aesAlg.CreateDecryptor(aesAlg.Key, aesAlg.IV), CryptoStreamMode.Write)){cs.Write(encryptedBytes, 0, encryptedBytes.Length);cs.FlushFinalBlock();decryptedBytes = ms.ToArray();}}return Encoding.UTF8.GetString(decryptedBytes);}}static void Main(){string plainText = "Hello, World!";string desKey = "abcdefgh"; // DES 密钥长度必须为 8 字节string tripleDesKey = "abcdefghijklmnopqrstuvwx"; // 3DES 密钥长度必须为 24 字节string aesKey = "abcdefghijklmnop"; // AES 密钥长度可以为 16、24 或 32 字节// DES 加密和解密string desCipherText = DESEncrypt(plainText, desKey);string desDecryptedText = DESDecrypt(desCipherText, desKey);Console.WriteLine($"DES 加密结果: {desCipherText}");Console.WriteLine($"DES 解密结果: {desDecryptedText}");// 3DES 加密和解密string tripleDesCipherText = TripleDESEncrypt(plainText, tripleDesKey);string tripleDesDecryptedText = TripleDESDecrypt(tripleDesCipherText, tripleDesKey);Console.WriteLine($"3DES 加密结果: {tripleDesCipherText}");Console.WriteLine($"3DES 解密结果: {tripleDesDecryptedText}");// AES 加密和解密string aesCipherText = AESEncrypt(plainText, aesKey);string aesDecryptedText = AESDecrypt(aesCipherText, aesKey);Console.WriteLine($"AES 加密结果: {aesCipherText}");Console.WriteLine($"AES 解密结果: {aesDecryptedText}");}
}    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/899782.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQLMesh调度系统深度解析:内置调度与Airflow集成实践

本文系统解析SQLMesh的两种核心调度方案:内置调度器与Apache Airflow集成。通过对比两者的适用场景、架构设计和操作流程,为企业构建可靠的数据分析流水线提供技术参考。重点内容包括: 内置调度器的轻量级部署与性能优化策略Airflow集成的端到…

centos线程数查看

查看当前最大支持的线程数 cat /proc/sys/kernel/threads-max当前用户进程可以创建的最大线程数(包括子进程) [rootlocalhost tmp]# ulimit -u得到当前实际的线程数 [rootlocalhost tmp]# ps -eLf | wc -l统计每个进程的总线程数前20的数据 [rootloc…

【大模型】视觉语言模型:Qwen2.5-VL的使用

官方github地址:https://github.com/QwenLM/Qwen2.5-VL 目录 Qwen家族的最新成员:Qwen2.5-VL 主要增强功能 模型架构更新 快速开始 使用Transformers聊天 Docker Qwen家族的最新成员:Qwen2.5-VL 主要增强功能 强大的文档解析功能&am…

HDMI接口设计

1. HDMI简介 HDMI(High Definition Multimedia Interface)高清多媒体接口,是首个支持在单线缆上传输,不经过压缩的全数字高清晰度、多声道音频和智能格式与控制命令数据的数字接口。这个接口可以同时传输视频信号、音频信号和控制信号。 从上图里面可以看到HDMI有3组数据信号…

C/C++ JSON 库综合对比及应用案例(六)

第六部分:C/C JSON 库综合对比及应用案例 📢 快速掌握 JSON!文章 视频双管齐下 🚀 如果你觉得阅读文章太慢,或者更喜欢 边看边学 的方式,不妨直接观看我录制的 JSON 课程视频!🎬 …

LXC 导入(Rockylinux,almalinux,oraclelunx,debian,ubuntu,openEuler,kail,opensuse)

前提要求 ubuntu下安装lxd 参考Rockylinux下安装lxd 参考LXC 源替换参考LXC 容器端口发布参考LXC webui 管理<

Spring MVC 页面跳转方案与区别

SpringMVC 的页面跳转方案主要分为 ‌转发&#xff08;Forward&#xff09;‌ 和 ‌重定向&#xff08;Redirect&#xff09;‌ 两类&#xff0c;具体实现方式和区别如下&#xff1a; 一、页面跳转方案 1. ‌转发&#xff08;Forward&#xff09;‌ 默认方式‌&#xff1a;直…

基于Spring Boot的轻型卡车零部件销售平台的设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…

高性能计算面经

高性能计算面经 C八股文真景一面凉经自我介绍&#xff0c;介绍一下你做过的加速的模块(叠噪&#xff0c;噪声跟原图有什么关系&#xff1f;)OpenGL和OpenCL有什么区别&#xff1f;**1. 核心用途****2. 编程模型****3. 硬件抽象****4. API设计****5. 典型应用场景****6. 互操作性…

青少年编程与数学 02-014 高中数学知识点 07课题、专业相关性分析

青少年编程与数学 02-014 高中数学知识点 07课题、专业相关性分析 一、函数与微积分1. 函数与初等函数2. 导数与优化 二、概率与统计1. 概率基础2. 统计推断3. 随机变量与分布 三、几何与代数1. 向量与矩阵运算2. 复数与坐标变换 四、数学建模与算法思维1. 数学建模2. 算法逻辑…

11乱码问题的解释(2)

这个字符串使用哪种方式编码的?---看包含在哪个文件中 和当前 mylabel.cpp 文件的编码方式是一致的~~ 如果这里显示的是 UTF-8&#xff0c;说明这个文件就是UTF-8 编码 如果显示的是 ANSI,说明这个文件就是 GBK 编码~ Qt Creator 内置的终端是 utf8 的方式来显示字符串吗?? …

我的机器学习学习之路

学习python的初衷 • hi&#xff0c;今天给朋友们分享一下我是怎么从0基础开始学习机器学习的。 • 我是2023年9月开始下定决心要学python的&#xff0c;目的有两个&#xff0c;一是为了提升自己的技能和价值&#xff0c;二是将所学的知识应用到工作中去&#xff0c;提升工作…

27--当路由器学会“防狼术“:华为设备管理面安全深度解剖(完整战备版)

当路由器学会"防狼术"&#xff1a;华为设备管理面安全深度解剖&#xff08;完整战备版&#xff09; 引言&#xff1a;网络世界的"门神"进化论 “从前有个路由器&#xff0c;它把所有数据包都当好人&#xff0c;直到有一天…” ——《悲惨世界网络版》 如果…

Docker容器网络相关设置

确认容器是否正确启动 首先&#xff0c;确保 MySQL 容器正在运行。可以使用 docker ps 查看当前正在运行的容器。如果 MySQL 容器没有启动&#xff0c;可以尝试以下命令启动它&#xff1a; docker run -d --name mysql-container -e MYSQL_ROOT_PASSWORDrootpassword mysql:8 这…

hive相关面试题以及答案

什么是Hive&#xff1f;它的作用是什么&#xff1f; 答&#xff1a;Hive是一个建立在Hadoop之上的数据仓库工具&#xff0c;它提供了类似于SQL的查询语言HiveQL来操作存储在Hadoop中的数据。Hive的主要作用是让用户能够使用SQL语法来查询和分析大规模数据集。 Hive的架构是什么…

前端学习记录之HTML

1. 网页 1.1 什么是网页 网站是指在因特网上根据一定的规则&#xff0c;使用HTML等制作的用于展示特定内容相关的网页集合。 网页是网站中的一“页”&#xff0c;通常是HTML格式的文件&#xff0c;它要通过浏览器来阅读 网页是构成网站的基本元素。它通常由图片&#xff0c;…

【1-1】ICT=IT+CT

前言 从这篇文章开始&#xff0c;我将总结软考网工相关的笔记和自己的所思所想。我所总结内容均来自互联网&#xff0c;欢迎大家交流、学习、讨论。 1. ICT ICT IT CT 这里&#xff0c;这三个缩写的对应英文如下&#xff1a; 缩写英文含义ICTInformation and Communicat…

多账号安全登录与浏览器指纹管理的实现方案

随着跨境电商、社交媒体运营等场景的普及&#xff0c;用户对多账号管理与反检测技术的需求日益增长。指纹浏览器作为一款专注于多账号安全登录与浏览器指纹管理的工具&#xff0c;通过虚拟浏览器环境隔离、动态指纹模拟等技术&#xff0c;解决了账号关联封禁的痛点。本文将从技…

CMake Presets教程

在使用 CMake 作为构建工具的时候, 对于一个稍微大一点的项目, 存在有很多的选项. 比如 Debug 版本还是 Release 版本, 是否开启特定选项, 是否开启测试等等. 这些通常是作为命令行参数传递进去的. 但是很多程序员并不在命令行中作开发, 更多的是使用 IDE 来进行开发. 不同的 I…

vue搭建一个树形菜单项目

首先搭建项目需要先通过步骤搭建一个vue的项目&#xff0c;然后创建一个component文件&#xff0c;里面新建一个index.vue页面来。 这是引入的element-ui组件库里的组件&#xff0c;来实现我的路由&#xff0c;渲染的是我存储的动态路由&#xff0c;所以需要先安装并且引用。 …