常用的加密算法介绍——MD5
haoteby 2025-01-14 13:52 1 浏览
我不是高手,我只是一个普通的程序员,我特别愿意大家留言讨论,批评指正,您给我指正了,我就去查资料,去做实验,我技术就能得到提高,我认为这是一个程序员的基本素养。
序言:程序员在实际的开发中会或多或少地用到一些加密的算法,如base64、md5、dex、aex、rsa等等。但是算法的种类很多,初学者经常会一头雾水,虽然也使用了,但是总感觉懵懵懂懂,今天我就对常用的一些算法做一个梳理和总结,我也不是高手,只是凭着自己的理解对自己以前用到过的做一个浅浅的整理,可能不知道的或者没介绍到的算法还有很多,希望大家留言指正。
一,算法的分类
1,hash算法(摘要算法):MD5,SHA1,SHA2(SHA256,SHA384,SHA512),此类算法只是摘要,是不可逆的,你拿到一个摘要值是没法还原出来原始数据的。
2,对称加密算法:DES,3DES,AES。
3,非对称加密算法:RSA
二,算法的使用
1,摘要算法的使用,首先摘要算法并不是加密算法,只是验证数据一致性的算法,摘要算法又称哈希算法、散列算法。比较常用的就是MD5,SHA256。摘要算法的最常使用场景就是比较信息的一致性,为什么不直接比较呢,因为有时候信息的数据量会很大,而MD5以后是可以提取一个32长度的摘要,只比较这个32位的字符串一致性就可以了。只要信息数据是一样的两个数据MD5以后的这个32位长度的摘要值就是一样的,哪怕你变化了一个字节,这个MD5以后的摘要值就不一样了。
下面我们做一个实验,linux下有个命令叫md5sum,windows下有个命令叫CertUtil。
随便找到一个文件,或者自己新建一个文件,linux下执行
md5sum aaa.txt
windows下执行
CertUtil -hashfile aaa.txt MD5
然后对文件内容做一下修改,再执行命令,发现这个摘要值已经发生了变化,再把内容改回去,发现又变回和刚才一样了。一般某些软件的官方下载网站都会提供一个该软件的MD5以后的hash值。如果下载了软件以后,或者是从其他渠道得到的软件。你都可以通过上面的命令来计算一下你手里的软件的hash值和官方提供的hash值是否一致,如果不一致你手里的文件就可能是被篡改过的,加了广告插件啊,或者下载不完整啊,或者版本不一致啊等等。
MD5还有一个常用的场景就是各种信息系统的密码存储,把用户设置的密码(正确的称呼其实是口令)以md5加密后的值存到数据库里,这样即使是系统被暴库了,看到的用户密码也都是MD5以后的,不是明文,也就没法知道用户设置的密码了。系统在用户登录的时候,也是把用户输入的密码进行MD5以后再跟数据库里存储的MD5后的密码进行比较就行了,为了安全,一般还会加上salt(盐值)。
下面演示一下常用的编程语言是如何进行MD5加密的。
java类
public static void main(String[] args) {
String dataStr = "hello";
try {
MessageDigest m = MessageDigest.getInstance("MD5");
m.update(dataStr.getBytes("UTF8"));
byte s[] = m.digest();
String result = "";
for (int i = 0; i < s.length; i++) {
String hexStr=Integer.toHexString((0x000000FF & s[i]) | 0xFFFFFF00);
result += Integer.toHexString((0x000000FF & s[i]) | 0xFFFFFF00).substring(6);
}
System.out.println(result);
} catch (UnsupportedEncodingException | NoSuchAlgorithmException e) {
e.printStackTrace();
}
}
如果是Spring boot项目就简单了,spring封装了工具类
String result = DigestUtils.md5DigestAsHex(base.getBytes());
System.out.println(result);
python
import hashlib
m = hashlib.md5()
m.update(b'hello')
result = m.hexdigest()
c#
using System.Security.Cryptography;
using System;
using System.Text;
namespace test.md5
{
public static void Main(string[] args)
{
string str = "hello";
MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
byte[] bytValue, bytHash;
bytValue = System.Text.Encoding.UTF8.GetBytes(str);
bytHash = md5.ComputeHash(bytValue);
Console.WriteLine(bytHash.Length);
StringBuilder sBuilder = new StringBuilder();
for (int i = 0; i < bytHash.Length; i++)
{
sBuilder.Append(bytHash[i].ToString("x2"));
Console.WriteLine(bytHash[i]);
}
md5.Clear();
Console.WriteLine(sBuilder);
}
}
- 上一篇:Java加密体系(MD5算法)
- 下一篇:python 实现md5加密
相关推荐
- 简单Labview实操案例
-
有几位条友私信我说Labview是怎么学的,怎么才能学好Labview,今天给大家简单介绍一下,如果想学上位机,Labview是相对来说比较容易上手的,而且开发速度也比较快,但是运行时候比较吃内存,...
- 关于LabVIEW用于仪器测控的自动测试程序的程序框架的选择问题!
-
有很长一段时间没有在公众号平台上输出、总结关于LabVIEW的知识文字内容了!主要是这段时间自己本职工作任务甚为繁重,加上各种家庭事宜的牵绊,耗费了过多的时间和精力,也就无力及时更新了。今天是端午节假...
- LabVIEW编程基础:分割条控件的使用
-
1、分割条控件简介同其它高级编程语言类似,在LabVIEW中分割条控件也是界面设计中常用的一种控件元素,利用分割条控件可以将前面板划分为多个独立的区域,每个区域都是一个单独的窗格,这些窗格具有前面板的...
- csgo一直显示正在连接到csgo网络怎么办?三招帮你解决
-
CSGO是一款射击类的游戏,它的全名叫反恐精英:全球攻势,是一款由VALVE与HiddenPathEntertainment合作开发、ValveSoftware发行的第一人称射击游戏,相信很...
- cs1.6没有bot怎么办
-
Hi~大家好啊,这里是聚合游戏,每天为你分享游戏相关的内容,喜欢的快来关注哟~...
- 《反恐精英:全球攻势2》 漏洞暴露玩家的IP地址
-
#文章首发挑战赛#据报道,在全球知名的电子游戏——CS2(《反恐精英:全球攻势2》)中存在一个HTML注入漏洞,这个漏洞被广泛利用来在游戏中注入图片并获取其他玩家的IP地址。...
- 《电子宠物》《007黄金眼》《雷神之锤》入选世界电子游戏名人堂
-
世界电子游戏名人堂5月8日公布了新的四位入选者《防卫者》《电子宠物》《007黄金眼》和《雷神之锤》,以向改变游戏行业规则的经典游戏致敬。世界电子游戏名人堂每年都会表彰那些具有持久热度并对视频游戏行业或...
- V社修复《反恐精英2》游戏漏洞:可抓取玩家IP地址、发起XSS攻击
-
IT之家12月12日消息,Valve旗下《反恐精英2》游戏被曝光新的安全漏洞,攻击者通过注入恶意代码来抓取玩家的IP地址,并能对同一游戏大厅中的所有玩家发起跨站脚本攻击(XSS)。攻击...
- 粉丝自制《CS》1.6重制版将于2025年登陆Steam
-
基于Valve官方起源引擎SDK,由多位“CSPromod”粉丝项目前开发人员从头构建的《反恐精英》1.6版本重制版《CS:Legacy》日前宣布将于2025年在Steam发布。开发团...
- 知名网游源代码泄漏 ,外挂潮将来?
-
SteamDatabase近日发布消息称Valve旗下游戏《反恐精英:全球攻势》(CS:GO)与《军团要塞2》(TF2)的源代码疑遭泄露。据了解,游戏源代码如果泄露的话,黑客可以更为轻松地开发出外挂,...
- 求斐波那契数列(Fibonacci Numbers)算法居然有9种,你知道几种?
-
ByLongLuo斐波那契数列...
- 三维基因组:Loop结构 差异分析(2)
-
通过聚合峰分析进行可视化既然已经找出了“WT”和“FS”条件之间的差异loop结构,就可以利用聚合峰分析(APA)来直观地展示loop结构调用的质量。APA是一种以Hi-C数据中的中心loop像...
- 用Excel制作动态图表(动态名称法)
-
动态图表也称交互式图表,指图表的内容可以随用户的选择而变化,是图表分析中比较高级的形式。使用动态图表能够突出重点数据,避免被其他不需要的数据干扰,从而提高数据分析效率。一个好的动态图表,可以让人从大量...