C# | 上位机开发新手指南(六)摘要算法
C# | 上位机开发新手指南(六)摘要算法
文章目录
- C# | 上位机开发新手指南(六)摘要算法
- 前言
- 常见摘要算法源码
- MD5算法
- SHA-1算法
- SHA-256算法
- SHA-512算法
- BLAKE2算法
- RIPEMD算法
- Whirlpool算法
前言
你知道摘要算法么?它在保障数据安全方面非常有用!
它能够将任意长度的数据转换成固定长度的消息摘要,从而确保数据的完整性和可靠性。比如说,我们下载软件的时候,就可以用摘要算法来检验软件是否被篡改,保障我们的电脑安全。
那这个算法的工作原理是怎样的呢?大致就是通过一系列复杂的计算,将原始数据转换为一个固定长度的摘要信息。而且无论输入的数据大小,输出的摘要信息长度都是一样的。
那么摘要算法有什么用处呢?比如数字签名,确保数据的来源和内容没有被篡改。还有密码学等领域的应用,可以说是非常厉害了!
那常见的摘要算法有哪些呢?比较常见的有MD5、SHA-1、SHA-2、SHA-3、BLAKE2、RIPEMD、Whirlpool和Keccak等。它们各有不同的优缺点和适用场景,我们需要根据实际情况来选择使用哦。
常见摘要算法源码
MD5算法
MD5是一种广泛使用的哈希算法,将任意长度的数据计算为128位的哈希值。尽管它被广泛使用,但是因为它已经被证明存在安全漏洞,现在已经不再被推荐使用。
示例代码:
using System;
using System.Security.Cryptography;
using System.Text;class Program
{static void Main(string[] args){string input = "Hello, world!";// 使用 MD5 算法生成摘要string md5Hash = GetMd5Hash(input);Console.WriteLine($"MD5 hash of {input}: {md5Hash}");}// 使用 MD5 算法生成摘要static string GetMd5Hash(string input){using (MD5 md5 = MD5.Create()){// 将输入字符串转换为字节数组byte[] inputBytes = Encoding.UTF8.GetBytes(input);// 计算哈希值byte[] hashBytes = md5.ComputeHash(inputBytes);// 将哈希值转换为字符串StringBuilder builder = new StringBuilder();for (int i = 0; i < hashBytes.Length; i++){builder.Append(hashBytes[i].ToString("x2"));}return builder.ToString();}}
}
代码中使用了 System.Security.Cryptography 命名空间中的 MD5 类。在方法中,先将字符串转换为字节数组,然后调用 MD5 类的 ComputeHash 方法生成哈希值,最后将哈希值转换为字符串返回。
SHA-1算法
SHA-1是一种用于计算数据哈希值的加密算法,将任意长度的数据计算为160位的哈希值。目前,SHA-1算法也已经被证明存在安全漏洞,现在不再被推荐使用。
示例代码:
using System;
using System.Security.Cryptography;
using System.Text;class Program
{static void Main(string[] args){string input = "Hello, world!";// 使用 SHA-1 算法生成摘要string sha1Hash = GetSha1Hash(input);Console.WriteLine($"SHA-1 hash of {input}: {sha1Hash}");}// 使用 SHA-1 算法生成摘要static string GetSha1Hash(string input){using (SHA1 sha1 = SHA1.Create()){// 将输入字符串转换为字节数组byte[] inputBytes = Encoding.UTF8.GetBytes(input);// 计算哈希值byte[] hashBytes = sha1.ComputeHash(inputBytes);// 将哈希值转换为字符串StringBuilder builder = new StringBuilder();for (int i = 0; i < hashBytes.Length; i++){builder.Append(hashBytes[i].ToString("x2"));}return builder.ToString();}}
}
代码中使用了 System.Security.Cryptography 命名空间中的 SHA1 类。在方法中,先将字符串转换为字节数组,然后调用 SHA1 类的 ComputeHash 方法生成哈希值,最后将哈希值转换为字符串返回。
SHA-256算法
SHA-256是一种用于计算数据哈希值的加密算法,将任意长度的数据计算为256位的哈希值。它是SHA-2算法族中的一员,比SHA-1更安全。
示例代码:
using System;
using System.Security.Cryptography;
using System.Text;class Program
{static void Main(string[] args){string input = "Hello, world!";// 使用 SHA-256 算法生成摘要string sha256Hash = GetSha256Hash(input);Console.WriteLine($"SHA-256 hash of {input}: {sha256Hash}");}// 使用 SHA-256 算法生成摘要static string GetSha256Hash(string input){using (SHA256 sha256 = SHA256.Create()){// 将输入字符串转换为字节数组byte[] inputBytes = Encoding.UTF8.GetBytes(input);// 计算哈希值byte[] hashBytes = sha256.ComputeHash(inputBytes);// 将哈希值转换为字符串StringBuilder builder = new StringBuilder();for (int i = 0; i < hashBytes.Length; i++){builder.Append(hashBytes[i].ToString("x2"));}return builder.ToString();}}
}
代码中使用了 System.Security.Cryptography 命名空间中的 SHA256 类。在方法中,先将字符串转换为字节数组,然后调用 SHA256 类的 ComputeHash 方法生成哈希值,最后将哈希值转换为字符串返回。
SHA-512算法
SHA-512是一种用于计算数据哈希值的加密算法,将任意长度的数据计算为512位的哈希值。它是SHA-2算法族中的一员,比SHA-256更安全。
示例代码:
using System;
using System.Security.Cryptography;
using System.Text;class Program
{static void Main(string[] args){string input = "Hello, world!";// 使用 SHA-512 算法生成摘要string sha512Hash = GetSha512Hash(input);Console.WriteLine($"SHA-512 hash of {input}: {sha512Hash}");}// 使用 SHA-512 算法生成摘要static string GetSha512Hash(string input){using (SHA512 sha512 = SHA512.Create()){// 将输入字符串转换为字节数组byte[] inputBytes = Encoding.UTF8.GetBytes(input);// 计算哈希值byte[] hashBytes = sha512.ComputeHash(inputBytes);// 将哈希值转换为字符串StringBuilder builder = new StringBuilder();for (int i = 0; i < hashBytes.Length; i++){builder.Append(hashBytes[i].ToString("x2"));}return builder.ToString();}}
}
代码中使用了 System.Security.Cryptography 命名空间中的 SHA512 类。在方法中,先将字符串转换为字节数组,然后调用 SHA512 类的 ComputeHash 方法生成哈希值,最后将哈希值转换为字符串返回。
BLAKE2算法
BLAKE2是BLAKE算法的改进版,是一种快速、安全的哈希函数,支持多种哈希长度,其中BLAKE2b和BLAKE2s分别支持512位和256位哈希值。它在安全性和性能方面都表现优异,被广泛应用于密码学和安全领域。
示例代码:
using System;
using System.Security.Cryptography;
using System.Text;class Program
{static void Main(string[] args){string input = "Hello, world!";// 使用 BLAKE2 算法生成摘要string blake2bHash = GetBlake2bHash(input);Console.WriteLine($"BLAKE2b hash of {input}: {blake2bHash}");string blake2sHash = GetBlake2sHash(input);Console.WriteLine($"BLAKE2s hash of {input}: {blake2sHash}");}// 使用 BLAKE2b 算法生成摘要static string GetBlake2bHash(string input){using (BLAKE2b blake2b = BLAKE2b.Create()){// 将输入字符串转换为字节数组byte[] inputBytes = Encoding.UTF8.GetBytes(input);// 计算哈希值byte[] hashBytes = blake2b.ComputeHash(inputBytes);// 将哈希值转换为字符串StringBuilder builder = new StringBuilder();for (int i = 0; i < hashBytes.Length; i++){builder.Append(hashBytes[i].ToString("x2"));}return builder.ToString();}}// 使用 BLAKE2s 算法生成摘要static string GetBlake2sHash(string input){using (BLAKE2s blake2s = BLAKE2s.Create()){// 将输入字符串转换为字节数组byte[] inputBytes = Encoding.UTF8.GetBytes(input);// 计算哈希值byte[] hashBytes = blake2s.ComputeHash(inputBytes);// 将哈希值转换为字符串StringBuilder builder = new StringBuilder();for (int i = 0; i < hashBytes.Length; i++){builder.Append(hashBytes[i].ToString("x2"));}return builder.ToString();}}
}
代码中使用了 System.Security.Cryptography 命名空间中的 BLAKE2b 和 BLAKE2s 类。在方法中,先将字符串转换为字节数组,然后调用 BLAKE2 类的 ComputeHash 方法生成哈希值,最后将哈希值转换为字符串返回。
RIPEMD算法
RIPEMD是一种比较老的哈希算法,支持多种哈希长度,其中RIPEMD-160和RIPEMD-256分别支持160位和256位哈希值。它在安全性方面比MD5强,但性能较慢。
示例代码:
using System;
using System.Security.Cryptography;
using System.Text;class Program
{static void Main(string[] args){string input = "Hello, world!";// 使用 RIPEMD-160 算法生成摘要string ripemd160Hash = GetRipemd160Hash(input);Console.WriteLine($"RIPEMD-160 hash of {input}: {ripemd160Hash}");// 使用 RIPEMD-256 算法生成摘要string ripemd256Hash = GetRipemd256Hash(input);Console.WriteLine($"RIPEMD-256 hash of {input}: {ripemd256Hash}");}// 使用 RIPEMD-160 算法生成摘要static string GetRipemd160Hash(string input){using (RIPEMD160 ripemd160 = RIPEMD160.Create()){// 将输入字符串转换为字节数组byte[] inputBytes = Encoding.UTF8.GetBytes(input);// 计算哈希值byte[] hashBytes = ripemd160.ComputeHash(inputBytes);// 将哈希值转换为字符串StringBuilder builder = new StringBuilder();for (int i = 0; i < hashBytes.Length; i++){builder.Append(hashBytes[i].ToString("x2"));}return builder.ToString();}}// 使用 RIPEMD-256 算法生成摘要static string GetRipemd256Hash(string input){using (RIPEMD256 ripemd256 = RIPEMD256.Create()){// 将输入字符串转换为字节数组byte[] inputBytes = Encoding.UTF8.GetBytes(input);// 计算哈希值byte[] hashBytes = ripemd256.ComputeHash(inputBytes);// 将哈希值转换为字符串StringBuilder builder = new StringBuilder();for (int i = 0; i < hashBytes.Length; i++){builder.Append(hashBytes[i].ToString("x2"));}return builder.ToString();}}
}
代码中使用了 System.Security.Cryptography 命名空间中的 RIPEMD160 和 RIPEMD256 类。在方法中,先将字符串转换为字节数组,然后调用 RIPEMD 类的 ComputeHash 方法生成哈希值,最后将哈希值转换为字符串返回。
Whirlpool算法
Whirlpool是一种强度很高的哈希算法,支持512位哈希值。它具有高度的安全性和抗碰撞性,并且被广泛应用于数字签名、身份验证和数据完整性验证等领域。
示例代码:
using System;
using System.Security.Cryptography;
using System.Text;class Program
{static void Main(string[] args){string input = "Hello, world!";// 使用 Whirlpool 算法生成摘要string whirlpoolHash = GetWhirlpoolHash(input);Console.WriteLine($"Whirlpool hash of {input}: {whirlpoolHash}");}// 使用 Whirlpool 算法生成摘要static string GetWhirlpoolHash(string input){using (Whirlpool whirlpool = Whirlpool.Create()){// 将输入字符串转换为字节数组byte[] inputBytes = Encoding.UTF8.GetBytes(input);// 计算哈希值byte[] hashBytes = whirlpool.ComputeHash(inputBytes);// 将哈希值转换为字符串StringBuilder builder = new StringBuilder();for (int i = 0; i < hashBytes.Length; i++){builder.Append(hashBytes[i].ToString("x2"));}return builder.ToString();}}
}
代码中使用了 System.Security.Cryptography 命名空间中的 Whirlpool 类。在方法中,先将字符串转换为字节数组,然后调用 Whirlpool 类的 ComputeHash 方法生成哈希值,最后将哈希值转换为字符串返回。
相关文章:
C# | 上位机开发新手指南(六)摘要算法
C# | 上位机开发新手指南(六)摘要算法 文章目录C# | 上位机开发新手指南(六)摘要算法前言常见摘要算法源码MD5算法SHA-1算法SHA-256算法SHA-512算法BLAKE2算法RIPEMD算法Whirlpool算法前言 你知道摘要算法么?它在保障…...
测试工程师:“ 这锅我不背 ” ,面对灵魂三问,如何回怼?
前言 在一个周末的早餐我被同事小周叫出去跑步,本想睡个懒觉,但是看他情绪不太稳定的样子,无奈艰难爬起陪他去跑步。 只见她气冲冲的对着河边大喊:真是冤枉啊!!! 原来是在工作中被莫名其妙背锅࿰…...
【Java闭关修炼】SpringBoot-SpringMVC概述和入门
SpringMVC概述和入门 MVC概述 实体类Bean:专门 存储业务数据 Student User业务处理Bean:指的是Service或者Dao 专门用来处理业务逻辑或者数据访问 用户通过视图层发送请求到服务器,在服务器中请求被Controller接受,Controller调用相应的MOdel层处理请求…...
pdf转换器免费版哪种好用:Aiseesoft PDF Converter Ultimate | 无损转word转Excel转PPT转图片啥都行!!!
Aiseesoft PDF Converter Ultimate 是一款优秀且高效可靠的无损电脑免费版pdf转换器软件,凭借卓越高识别精度的强悍OCR识别技术,可精准识别英文、法文、中文、德文、日文、韩文、意大利文、土耳其文等190多个国家的语言以及各种公式和编程语言࿰…...
革新市场营销,突破瓶颈:关键词采集和市场调查的秘密武器
近年来,全球新兴行业不断涌现,其中一些行业甚至成为了热门话题。这些新兴行业的出现,不仅带来了新的商机和发展机遇,也对传统产业带来了冲击和挑战。对于那些想要进入新兴行业的人来说,了解这些行业的关键词和市场情况…...
3年测试经验只会“点点点”,不会自动化即将面临公司淘汰?沉淀100天继续做测试
前段时间一个朋友跟我吐槽,说自己做软件测试工作已经3年了,可这三年自己的能力并没有得到提升,反而随着互联网的发展,自己只会“点点点”的技能即将被淘汰。说自己很苦恼了,想要提升一下自己,可不知道该如何…...
python:异常处理与文件操作(知识点详解+代码展示)
文章目录一、异常处理1、try...except语句2、finally语句二、断言1、定义2、举例例一:例二:三、文件操作1、写文件操作2、读文件操作学习目标:1、掌握异常处理的方法2、掌握断言的使用3、掌握打开文件、读文件和写文件的方法一、异常处理 引…...
SpringBoot 过滤器和拦截器(三十八)
我喜欢你,可是你却并不知道. 上一章简单介绍了SpringBoot参数验证(三十七) ,如果没有看过,请观看上一章 关于过滤器和拦截器已经讲很多了, 这里老蝴蝶只说一下 SpringBoot 的用法。 可以看之前的文章: https://blog.csdn.net/yjltx1234csdn/article/d…...
Memcache论文总结——Lec16
文章目录一、相关名词1.mcrouter层2.GUTTER SERVER3.mcsqueal4.remote mark二、当流量增长了如何SCALE 你的网站?三、背景及业务特点1.读多写少2.FB需求:3.之前情况四、简介五、FaceBook的架构五、Cache Policy六、In a Cluster : Latency and Load(一&a…...
父子组件传值问题
文章目录前言一、问题描述二、问题解决前言 在写毕业设计,涉及了一些前端Vue.js的组件传值知识并出现了相关问题,因此进行记录。 问题 Vue.js的使用不熟练,相关组件、props等掌握不清晰前端代码书写不规范 望指正! 一、问题描述 …...
Redis大key问题
Redis大key问题 什么是big key? bigKey的危害: 大key不仅仅是占用内存而已,如果是仅仅内存的问题 那么扩大内存就好了。禁止大key是主要是因为你操作redis,比如说读/写等操作redis的时候 会有io操作,大key会导致io操作…...
00后卷王的自述,我难道真的很卷?
前言 前段时间去面试了一个公司,成功拿到了offer,薪资也从12k涨到了18k,对于工作都还没两年的我来说,还是比较满意的,毕竟一些工作3、4年的可能还没我高。 我可能就是大家说的卷王,感觉自己年轻ÿ…...
Redis第七讲 Redis存储模型详解
Redis存储模型 每次在Redis数据库中创建一个键值对时,至少会创建两个对象,一个是键对象,一个是值对象,而Redis中的每个对象都是由 redisObject 结构来表示.redisObject的结构与对象类型、内存编码、内存回收、共享对象都有关系,一个redisObject对象的大小为16字节:4bit+…...
Python 进阶指南(编程轻松进阶):十五、面向对象编程和类
原文:http://inventwithpython.com/beyond/chapter15.html OOP 是一种编程语言特性,允许你将变量和函数组合成新的数据类型,称为类,你可以从中创建对象。通过将代码组织成类,可以将一个整体程序分解成更容易理解和调试…...
windows下postgresql安装timescaledb
timescaledb是一个时序数据库,可以创建超表hypertable。它并不是一个独立的数据库,它依赖于postgresql,目前相当于postgresql的一个插件或者扩展。 要安装timescaledb,需要先安装postgresql。 这里安装的postgresql是12.14版本&am…...
Linux系统常用命令大全
本教程将介绍Linux系统的基本操作,包括文件操作、用户管理和软件安装等。 1. 文件操作 1.1 查看文件内容 使用cat命令可以查看文件的内容,例如:cat file.txt 1.2 创建新文件 使用touch命令可以创建新文件,例如:to…...
月报总结|Moonbeam 3月份大事一览
本月,Moonbeam在社区治理上进入了全新的阶段 — — 针对第一批生态系统Grants的Snapshot投票结果揭晓,链上公投已在进行中,社区获得了更多表达的机会与权力,这些项目也将为生态注入新的活力。 活动方面,Moonriver Ris…...
多功能料理锅语音播放芯片——NV040C
多功能料理锅就是一锅搭配多个锅盘,可以实现火锅、烤肉、花式煎蛋、丸子等多种烹饪功能。 多功能料理锅语音方案设计需求: 多功能锅本身体积有限,按钮比较少,相应功能的字体要贴按钮旁边,字体也是比较小的,…...
vue23自定义svg图标组件
可参考: 未来必热:SVG Sprites技术介绍 懒人神器:svg-sprite-loader实现自己的Icon组件 在Vue3项目中使用svg-sprite-loader 前置知识 在页面中,虽然可以通过如下的方式使用img标签,来引入svg图标。但是,…...
相机雷达时间同步(基于ROS)
文章目录运行环境:思路:同步前和同步后效果对比1.1创建工作空间1.2创建功能包2.1编写源文件2.2编写头文件2.3编写可执行文件2.4配置文件3.1编译运行4.1录制时间同步后的rosbag4.2rviz可视化rosbag运行环境: ubuntu20.04 noetic usb_cam 速腾R…...
【kafka】Golang实现分布式Masscan任务调度系统
要求: 输出两个程序,一个命令行程序(命令行参数用flag)和一个服务端程序。 命令行程序支持通过命令行参数配置下发IP或IP段、端口、扫描带宽,然后将消息推送到kafka里面。 服务端程序: 从kafka消费者接收…...
Opencv中的addweighted函数
一.addweighted函数作用 addweighted()是OpenCV库中用于图像处理的函数,主要功能是将两个输入图像(尺寸和类型相同)按照指定的权重进行加权叠加(图像融合),并添加一个标量值&#x…...
《用户共鸣指数(E)驱动品牌大模型种草:如何抢占大模型搜索结果情感高地》
在注意力分散、内容高度同质化的时代,情感连接已成为品牌破圈的关键通道。我们在服务大量品牌客户的过程中发现,消费者对内容的“有感”程度,正日益成为影响品牌传播效率与转化率的核心变量。在生成式AI驱动的内容生成与推荐环境中࿰…...
ElasticSearch搜索引擎之倒排索引及其底层算法
文章目录 一、搜索引擎1、什么是搜索引擎?2、搜索引擎的分类3、常用的搜索引擎4、搜索引擎的特点二、倒排索引1、简介2、为什么倒排索引不用B+树1.创建时间长,文件大。2.其次,树深,IO次数可怕。3.索引可能会失效。4.精准度差。三. 倒排索引四、算法1、Term Index的算法2、 …...
Spring数据访问模块设计
前面我们已经完成了IoC和web模块的设计,聪明的码友立马就知道了,该到数据访问模块了,要不就这俩玩个6啊,查库势在必行,至此,它来了。 一、核心设计理念 1、痛点在哪 应用离不开数据(数据库、No…...
MySQL账号权限管理指南:安全创建账户与精细授权技巧
在MySQL数据库管理中,合理创建用户账号并分配精确权限是保障数据安全的核心环节。直接使用root账号进行所有操作不仅危险且难以审计操作行为。今天我们来全面解析MySQL账号创建与权限分配的专业方法。 一、为何需要创建独立账号? 最小权限原则…...
Linux离线(zip方式)安装docker
目录 基础信息操作系统信息docker信息 安装实例安装步骤示例 遇到的问题问题1:修改默认工作路径启动失败问题2 找不到对应组 基础信息 操作系统信息 OS版本:CentOS 7 64位 内核版本:3.10.0 相关命令: uname -rcat /etc/os-rele…...
区块链技术概述
区块链技术是一种去中心化、分布式账本技术,通过密码学、共识机制和智能合约等核心组件,实现数据不可篡改、透明可追溯的系统。 一、核心技术 1. 去中心化 特点:数据存储在网络中的多个节点(计算机),而非…...
【把数组变成一棵树】有序数组秒变平衡BST,原来可以这么优雅!
【把数组变成一棵树】有序数组秒变平衡BST,原来可以这么优雅! 🌱 前言:一棵树的浪漫,从数组开始说起 程序员的世界里,数组是最常见的基本结构之一,几乎每种语言、每种算法都少不了它。可你有没有想过,一组看似“线性排列”的有序数组,竟然可以**“长”成一棵平衡的二…...
怎么开发一个网络协议模块(C语言框架)之(六) ——通用对象池总结(核心)
+---------------------------+ | operEntryTbl[] | ← 操作对象池 (对象数组) +---------------------------+ | 0 | 1 | 2 | ... | N-1 | +---------------------------+↓ 初始化时全部加入 +------------------------+ +-------------------------+ | …...
