美文网首页
HASH中的MD5

HASH中的MD5

作者: 爱搞事的Snoopy | 来源:发表于2017-01-05 17:31 被阅读501次

关于MD5安全性的讨论

MD5的常识性知识

  • 一个密码系统的安全性只在于密钥的保密性,而不在于算法的保密性.
  • MD5就是把不论什么长度的文字内容,给精简成128位散列数.不论文字内容只有一个字母a,还是1w多字的长篇论文,都精简(或填充)成128位散列数.
  • MD5主要用在文档校验上,用来生成密钥检测文档是否被篡改.
  • MD5算法本身是不可被破解的.
  • 目前没有软件能有效地破解 MD5.大多数时候只是把常见字符串的 MD5 存了起来为彩虹表,通过一定的算法,进行匹配.
  • 厉害的软件还会在彩虹桥的基础上加入哈希碰撞.
  • MD5 目前来说还是可以用的,尤其是考虑到合适的加盐以后可以解决大多数彩虹表带来的危险.
    所有的不被破解的基础,一定要做到秘钥保密!秘钥保密!秘钥保密!

一些知识点的补充

图片与文章无关.jpg

哈希

Hash,一般翻译做"散列”,也有直接音译为"哈希"的,就是把任意长度的输入(又叫做预映射, pre-image),通过散列算法,变换成固定长度的输出,该输出就是散列值。这种转换是一种压缩映射,也就是,散列值的空间通常远小于输入的空间,不同的输入可能会散列成相同的输出,而不可能从散列值来唯一的确定输入值.
简单的说就是一种将任意长度的消息压缩到某一固定长度的信息摘要的函数.
HASH主要用于信息安全领域中加密算法,他把一些不同长度的信息转化成杂乱的128位的编码里,叫做HASH值. 也可以说,hash就是找到一种数据内容和数据存放地址之间的映射关系.
Hash算法在信息安全方面的应用主要体现在以下的3个方面:

  1. 文件校验
    我们比较熟悉的校验算法有奇偶校验和CRC校验,这2种校验并没有抗数据篡改的能力,它们一定程度上能检测并纠正数据传输中的信道误码,但却不能防止对数据的恶意破坏.
    MD5 Hash算法的"数字指纹"特性,使它成为目前应用最广泛的一种文件完整性校验和(Checksum)算法,不少Unix系统有提供计算md5 checksum的命令.

  2. 数字签名
    Hash 算法也是现代密码体系中的一个重要组成部分。由于非对称算法的运算速度较慢,所以在数字签名协议中,单向散列函数扮演了一个重要的角色。 对 Hash 值,又称"数字摘要"进行数字签名,在统计上可以认为与对文件本身进行数字签名是等效的.而且这样的协议还有其他的优点.

  3. 鉴权协议
    如下的鉴权协议又被称作"挑战--认证模式:在传输信道是可被侦听,但不可被篡改的情况下,这是一种简单而安全的方法.
    -以上解释摘自百度

彩虹表

如果将哈希后的密文比作一把锁,暴力破解的方法就是现场制作各种各样不同齿形的钥匙,再来尝试能否开锁,这样耗时无疑很长;我以前错误理解的“彩虹表”,是事先制作好所有齿形的钥匙,全部拿过来尝试开锁,这样虽然省去了制作钥匙的时间,但是后来发现这些钥匙实在是太多了,没法全部带在身上。而真正的彩虹表,是将钥匙按照某种规律进行分组,每组钥匙中只需要带最有特点的一个,当发现某个“特征钥匙”差一点就能开锁了,则当场对该钥匙进行简单的打磨,直到能开锁为止。这种方法是既省力又省时的.

哈希碰撞

哈希碰撞就是一种优化过算法,其基本原理就是把密码明文对应的MD5与你的MD5进行对比,因为经过一些优化,所以无论是时间上,还是空间都很很快.其优化方法我也没研究过,不过感兴趣的可以查一下王小云教授关于哈希碰撞的论文.

常用破解MD5方法

目前来说,破解MD5加密的最有效的方法就是 哈希碰撞+彩虹表+对应秘钥,一些网络黑客会在一些明文存储用户密码的网站上窃取信息,假如黑客有一亿条数据,因为都是真实用户所以经过哈希碰撞之后,你的密码被破译出来的几率就真的非常大了,那破译不出来的可能就是因为大小写和一些特殊符号,这就用到了彩虹表,最后就是你的秘钥,比如你是之前对用户的密码进行加盐,还是之后对MD5之后的字符串进行的特殊处理,只要对方知道你的秘钥,那么你密码被破译出来的几率就非常非常高了,所以我们说: 一个密码系统的安全性只在于密钥的保密性,而不在于算法的保密性.

总结

MD5本身是不可逆和无冲突的,但是用一些巧妙地方法会被破解出来.一个密码系统的是没有绝对安全的,密码系统只是增加了被破解的代价.

PS:一切明文存储用户密码的网站都是耍流氓!

耍流氓的正确姿势.jpg

相关文章

  • python的MD5加密

    #MD5加密 import hashlib # 创建md5对象 hash= hashlib.md5() hash....

  • PHP字符串处理函数

    md5_file() Calculates the md5 hash of a given file md5() ...

  • HASH中的MD5

    关于MD5安全性的讨论 MD5的常识性知识 一个密码系统的安全性只在于密钥的保密性,而不在于算法的保密性. MD5...

  • MD5

    MD5使用接口NSString+Hash.h MD5使用ViewController.m

  • 2018-11-20 datetime &logging

    -昨天的作业-hash应用,用户名和密码password md5 -》数据库中md5 是单向加密,不可能解开碰撞,...

  • HashMap相关

    hash概念 hash:是一种信息摘要算法,它还叫做哈希,或者散列。我们平时使用的MD5中的公私钥验证都属于Has...

  • 负载均衡中的一致性hash算法

    hash简介 说到底,他是一种hash算法,那什么是hash算法?hash算法是一种散列算法,常用的比如MD5。抽...

  • webapck构建文件命名hash chunkhash cont

    hash是通过既定的数据摘要算法(目前使用最广泛的是md5)计算出来的hash值。 webpack内置的hash相...

  • Java 实现 MD5

    本文介绍 Java 语言实现 MD5 Hash 的多种方法。 目录 MD5 简介 实现方法基于 Java API基...

  • 2.哈希加密 & base64加密

    一、哈希HASH 哈希(散列)函数MD5 SHA1/256/512 HMAC Hash的特点: 1.算法是公开...

网友评论

      本文标题:HASH中的MD5

      本文链接:https://www.haomeiwen.com/subject/dpvzvttx.html