专题:什么是MD5?
一、概念
MD5在软件行业是再常见不过的一个词了,即使你从没使用过它,也不知道它到底是个什么东西,但你肯定听过这个词。
那么到底什么是MD5呢?是加密算法吗?不是的,它是一种信息摘要算法,它可以从一个字符串或一个文件中按照一定的规则生成一个特殊的字符串(这个特殊的字符串就被称之为摘要,我理解就是从文件中摘一些信息片段加工而来),并且一个文件所对应的MD5摘要是固定的,当文件内容变化后,其MD5值也会不一样(虽然理论上来说也有可能会一样,但概率极小),因此,在应用中经常使用MD5值来验证一段数据有没有被篡改。比如,在数据的发送方将原始数据生成出MD5值,然后把原始数据连同其MD5值一起传给接收方,接收该收到数据后,先将原始数据用MD5算法生成摘要信息,然后再将此摘要信息与发送方发过来的摘要信息进行比较,如果一致就认为原始数据没有被修改,否则原始数据就是被修改过了。
二、特点
MD5值有几个特点:
1、它是一段固定长度的数据,即128bit的由“0”和“1”组成的一段二进制数据。无论原始数据是多长或多短,其MD5值都是128bit。
2、通常(或者叫行业规定),这段128bit的数据,按4bit一组分成32组,每一组按16进制来计算其值,并以字符的形式输出每个值。比如一组数据按16进制计算出来的值是0-9,打印出来也是0-9,如果计算出来的值是a-f,如果直接打印的话将会是10-15,在java中可以使用String.format("%02x", bytes[i])方法来将16进制的 a-f 打印成字母“a-f”,最终这个128bit的数据将会被打印成一个32位的字符串。所以我们通常所说的MD5值就是指这串32位的由“0-9,a-f”所组成的字符串。如果你看到某个MD5不是32位,或发现其中含有“0~f”之外的字符,那肯定是个错误的MD5值。
3、确定性,一个原始数据的MD5值是唯一的,同一个原始数据不可能会计算出多个不同的MD5值。
4、碰撞性,原始数据与其MD5值并不是一一对应的,有可能多个原始数据计算出来的MD5值是一样的,这就是碰撞。
5、不可逆。也就是说如果告诉你一个MD5值,你是无法通过它还原出它的原始数据的,这不是你的技术不够牛,这是由它的算法所决定的。因为根据第4点,一个给定的MD5值是可能对应多个原始数据的,并且理论上讲是可以对应无限多个原始数据,所有无法确定到底是由哪个原始数据产生的。
专题:什么是MD5?相关推荐
- diamond专题(一)-- 简介和快速使用
大家好,今天开始为大家带来我们通用产品团队的产品 -- diamond的专题,本次为大家介绍diamond的概况和快速使用. 一.概况 diamond是淘宝内部使用的一个管理持久配置的系统,它的特点是 ...
- hashmap中用红黑树不用其他树_HashMap面试专题:常问六题深入解析
引言 其实我很早以前就想写一篇关于HashMap的面试专题.对于JAVA求职者来说,HashMap可谓是集合类的重中之重,甚至你在复习的时候,其他集合类都不用看,专攻HashMap即可. 然而,鉴于网 ...
- [Lab 2] OSPF专题
[Lab 2] OSPF专题 OSPF(Open Shortest Path First,开放最短链路优先)路由协议是典型的链路状态路 由协议.OSPF 由IETF 在20 世纪80 年代末期开发,O ...
- 《密码与安全新技术专题》第1周作业
20180908 2018-2019-2 <密码与安全新技术专题>第1周作业 课程:<密码与安全新技术专题> 班级: 1892 姓名: 杨晨曦 学号:20189208 上课教师 ...
- Jmeter MD5加密及其运用
常用的几种加密方式 内置函数_MD5加密 参数说明: String to calculate MD5 hash(必填):要加密的字符串 Name of variable in which to sto ...
- 渗透测试-CTF_AWD专题篇
CTF专题篇 CTF-比赛培训基础 1 CTF 介绍 HTTP协议分析 进阶 001.CTF简介_宽字节注入 高级 2018CTF--黑客大赛特训 CTF-PWN PWN CTF竞赛中的主要题型之一 ...
- 20189217 2018-2019-2 《密码与安全新技术专题》第1周作业
20189217 2018-2019-2 <密码与安全新技术专题>第1周作业 课程:<密码与安全新技术专题> 班级: 1892 姓名: 张鸿羽 学号:20189217 上课教师 ...
- php中md5加密函数怎么用,PHP加密函数—md5()函数加密实例用法
PHP加密函数-md5()函数加密 什么是MD5()函数? MD5()函数是计算器字符串的 MD5散列值,使用MD5的算法,MD5的全称是Message-Digest Algorithm 5,它的作用 ...
- 网络通信专题总结之OTA专题
大纲: |网络通信专题总结之OTA专题 |OTA简介 |OTA模式以及分类 |用户个性化定制更新业务流程讲述 |具体是怎样实现: |APP |嵌入式端 获取url.md5.版本号 请求服务器 下载与存 ...
最新文章
- Windows进程与线程学习笔记(五)—— 模拟线程切换
- Linux上DNS实现工具之bind详叙
- 服务器控件 原生html,应用样式到HTML服务器控件
- Ironport对邮件主题中包括特殊字符的过滤
- MSSqlServer基础学习01
- 一只老猴子说的话,太经典了!
- LMS赛区公告:DG战队因假赛被永久除名
- 安卓 background的图片随着textview的大小而改变_关于CSS中的背景属性background简述...
- 【安装包】gcc编译器
- Ruby module ---模块,组件
- PhpQuery PHP操作HTML类,PHP操作XML类,PHP操作Dom类
- php去掉省市区,PHP简单实现正则匹配省市区的方法
- img 标签的 height 和 width 属性设置图像的尺寸。
- 腾讯云PCDN:从P2P到万物互联服务框架
- 广告行业中那些趣事系列43:小布语音助手知识问答比赛优化实践
- python中做为词云轮廓的图片,Python如何生成词云图片
- 孙俊 计算机技术资格水平考试,孙俊 - 专家学者 - - 计算机科学与技术 - 中南大学 - 学科服务平台...
- python生成快递取件码_快递,顺丰,python,截图,15Seconds
- (转)如何治疗颈椎突 - 对程序员来说很有用
- 算法导论读书笔记(19)
热门文章
- Ubuntu16.04下Qt交叉编译开发环境搭建
- kafka —— consumers 消费者 group 找不到得原因
- 实战 Vue 之实现拖曳排序功能
- Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.1.0:resources (default-reso
- 磁场强度单位和磁感应强度单位转换
- 5年开发经验的阿里巴巴Java程序员分享从业心得总结,帮助还在迷茫的朋友
- maven子包打包的时候[WARNING]
- egret游戏入门之学习资源篇
- 这套系统,可能真的是数据分析师们未来5年的机遇!
- 【C# 教程系列第 12 篇】抽象类的简单实现