首页 > 编程语言 >MD5加密算法

MD5加密算法

时间:2023-11-27 15:14:25浏览次数:31  
标签:填充 信息 分组 md5 512 加密算法 MD5

MD5

MD5是一种不可逆的加密算法。可以产生出一个128位(16字节)的散列值(hash value),用于确保信息传输完整一致

md5的特性

  • 压缩性:任意长度的数据,算出的MD5值长度都是固定的。

  • 容易计算:从原数据计算出MD5值很容易。

  • 抗修改性:对原数据进行任何改动,哪怕只修改1个字节,所得到的MD5值都有很大区别。

  • 弱抗碰撞:已知原数据和其MD5值,想找到一个具有相同MD5值的数据(即伪造数据)是非常困难的

md5加密原理

MD5以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值

1、填充

在MD5算法中,首先需要对信息进行填充,使其位长对512求余的结果等于448,并且填充必须进行,即使其位长对512求余的结果等于448。因此,信息的位长(Bits Length)将被扩展至N*512+448,N为一个非负整数

填充的方法如下:

1) 在信息的后面填充一个1和无数个0,直到满足上面的条件时才停止用0对信息的填充。

2) 在这个结果后面附加一个以64位二进制表示的填充前信息长度(单位为Bit),如果二

进制表示的填充前信息长度超过64位,则取低64位。

经过这两步的处理,信息的位长=N512+448+64=(N+1)512,即长度恰好是512的整数倍

2、初始化变量

MD5中有四个32位被称作链接变量(Chaining Variable)的整数参数,他们分别为:A=0x01234567,B=0x89abcdef,C=0xfedcba98,D=0x76543210。当设置好这四个链接变量后,就开始进入算法的四轮循环运算,循环的次数是信息中512位信息分组的数目

3、处理分组数据

首先我们声明四个中间变量a,b,c,d,赋值:a = A, b = B, c = C, d = D

主循环有四轮(MD4只有三轮),每轮循环都很相似。第一轮进行16次操作。每次操作对a、b、c和d中的其中三个作一次非线性函数运算,然后将所得结果加上第四个变量(文本中的一个子分组和一个常数),再将所得结果向右环移一个不定的数

这些完成之后,将a、b、c、d分别在原来基础上再加上A、B、C、D,然后用该结果取代a、b、c、d,然后用下一分组数据继续运行算法

4、输出

最后的输出是a、b、c和d的级联,组成128位输出结果

撞库

从技术的角度来说,MD5真的很安全,因为MD5本身是不可逆的,因此没法解密,除了撞库这样的一个方式

通过建立大型数据库,将常用的各种句子密码等加密成为密文,并存储在数据库中;然后拿着密文到数据库网站查询,就有可能查到密码

在大数据时代,庞大的数据中收集了越来越多的原文密文字典,利用反查法(md5的缺点就是相同密码加密的结果是一样的,也就是同一个密码加密后具备唯一性的特征),只要字典中存在弱密码的md5加密串,那么就可以反向查找出对应密码

程序开发人员如何避免反查法,降低被解密的可能性,那么就需要使用盐值加密,加入一个随机盐,这样一定程度上可以防止md5大数据字典法解密用户信息。只要随机盐不泄露,那么被解密的风险就降低了

标签:填充,信息,分组,md5,512,加密算法,MD5
From: https://www.cnblogs.com/yogayao/p/17859383.html

相关文章

  • 在 Blazor WASM 中手撸一个.NET MD5类
    最近.net8blazorauto大火,我也玩了一下,发现ssr能用的代码MD5类在wasm是没法用的.于是搜索了一下互联网,找到了一份代码,分享给大家.我找到的帖子作者原话:代码不是我的,但我确实稍微修改了它以使其与System.Security.Cryptography.MD5类更加一致。publicstaticclass......
  • 深入理解RC4加密算法
    RC4(RivestCipher4)是一种广泛应用的加密算法,由RonaldL.Rivest于1987年发明。它是一种流密码(streamcipher)算法,适用于对网络通信中的数据进行加密保护。RC4加密解密--一个覆盖广泛主题工具的高效在线平台(amd794.com)https://amd794.com/rc4encordec1.RC4的工作原理RC4的核心......
  • 深入理解RC4加密算法
    RC4(RivestCipher4)是一种广泛应用的加密算法,由RonaldL.Rivest于1987年发明。它是一种流密码(streamcipher)算法,适用于对网络通信中的数据进行加密保护。RC4加密解密--一个覆盖广泛主题工具的高效在线平台(amd794.com)https://amd794.com/rc4encordec1.RC4的工作原理RC4的......
  • Crypto_BUUCTF_WriteUp | 丢失的 MD5
    题目(一个py文件分析对程序根据python3语法进行debug(因为我装的版本是python3):运行得到MD5码按格式提交即可。Flagflag{e9032994dabac08080091151380478a2}参考python学习——hashlib.md5摘要算法(哈希算法)-geerniya-CSDNStringsmustbeencodedbeforehashin......
  • 简单的文件加密程序(md5xor异或winlinux)
    简介小程序是基于md5+password+xor的组合方式来加密文件。程序支持跨平台(Windows/Linux)。使用方法: 源文件清单:main.c  md5.c  md5.h  setup.sh 完整代码(main.c):#include<stdio.h>#include<stdlib.h>#include<string.h>#include<errno.h>#i......
  • ASP.NET MD5与哈希加密
    ......
  • 通过网络远程传输文件时md5不一致的问题
    今天远程复制文件的时候碰到了一个问题,就是复制到远程机器的压缩文件打开提示错误。然后我查看了一下本地机器和远程机器的该文件的md5,结果发现果然不一样。 我的脑海里冒出了许多可能:网络传输在极低概率下还是可能出现数据错误的;可能是被经过某些恶意网络节点的时候被更改了......
  • DES对称加密算法Java实现
    DES对称加密算法Java实现源代码AESUtils.java//packageme.muphy.util;importjavax.crypto.*;importjavax.crypto.spec.SecretKeySpec;importjava.nio.charset.StandardCharsets;importjava.security.InvalidKeyException;importjava.security.NoSuchAlgorithmExcept......
  • 【Azure Storage Blob】如何通过.NET Azure Storage Blobs SDK获取到Blob的MD5值呢?
    问题描述通过.NETAzureStorageBlobsSDK,获取Blob的MD5值,查看了Azure操作手册中,介绍可以使用 blob.Properties.ContentMD5属性。//blob文件测试CloudBlobClientblobClient=storageAccount.CreateCloudBlobClient();CloudBlobContainercontainer=blobClient......
  • 小程序可用emoji加密md5.js
    小程序的昵称有emoji表情,之前网上找的md5库加密后和php加密的md5不一样用下面的代码可以解决此问题//https://github.com/blueimp/JavaScript-MD5(function($){'usestrict'/***Addintegers,wrappingat2^32.*Thisuses16-bitoperationsinternallyt......