您的位置:早安暖心话>美文美句>个性签名>正文

理解数字签名和加密通信等技术的关键算法哈希算法的介绍

人气:377 ℃/2022-01-13 17:13:06

核心提示:哈希,英文是 hash ,本来意思是切碎并搅拌,有一种食物就叫 Hash ,就是把食材切碎并搅拌一下做成的。哈希函数的运算结果就

哈希,英文是 hash ,本来意思是切碎并搅拌,有一种食物就叫 Hash ,就是把食材切碎并搅拌一下做成的。哈希函数的运算结果就是哈希值,通常简称为哈希。哈希函数有时候也翻译做散列函数。

根据维基百科的定义,哈希函数要做的事情是给一个任意大小的数据生成出一个固定长度的数据,作为它的映射,所谓映射就是一一对应。

第一是安全,给定数据 M 容易算出哈希值 X ,而给定 X 不能算出 M ,或者说哈希算法应该是一个单向算法。

第三是长度固定,给定一种哈希算法,不管输入是多大的数据,输出长度都是固定的。

但是仔细想一下,如果哈希的长度是固定的,也就是取值范围是有限的,而输入数据的取值范围是无限的,所以总会找到两个不同的输入拥有相同的哈希,所以,哈希函数的安全性肯定是个相对概念。

如果出现了两个不同输入有相同输出的情况,就叫碰撞,collision 。不同的哈希算法,哈希位数越多,也就基本意味着安全级别越高,或者说它的抗碰撞性就越好。

再来语录哈希函数的主要作用,哈希的独一无二性,保证了如果数据在存储或者传输过程中有丝毫损坏,那么它的哈希就会变。哈希函数的最常见的一个作用就是进行完整性校验( Integrity Check ),完整的意思是数据无损坏。

哈希有很多不同的称呼,有时候叫Digest(摘要),有时候叫Checksum(校验值),有时候叫Fingerprint(指纹),其实说的意思差不多,也就是说哈希可以用来代表数据本身。

例如朋友给我传递一份数据,传完之后,我有一份,他手里也有一份,如果两份数据的哈希值是一样的,那么这两份数据的内容就是一样的,或者说可以认为传递过程中数据没有损坏,我手里拿到的数据是完整的。

所以说,哈希函数的基本作用就是给大数据算出一个摘要性的长度固定的字符串,也就是所谓的哈希。

哈希算法有很多种,例如md5、SHA256等等,但是它们总体上可以分为两大类,一类是普通哈希,另外一类是加密哈希(cryptographic hash function)。

业界可以找到的哈希算法是有很多种的。我们可以大致按照输出的哈希的长度来聊,虽然哈希算法的安全性也不单单是跟哈希长度有关,但是一般哈希值越长也就是越安全。

例如CRC-32的输出是32 bit,也就是32位的二进制数,表示成十六进制就是8位。MD5算法的哈希是32位16进制数,比较常见;SHA-256是256个Bit ,十六进制表示就是64位。

这些算法可以分成普通哈希和加密哈希算法,两种算法之间没有特别明显的区别。例如本来MD5就是设计出来做加密哈希的,但是后来由于计算机的发展MD5出现碰撞的可能性就很大了,所以目前MD5只能当普通哈希用,用来做数据校验。

加密哈希跟普通哈希的区别就是安全性,一般原则是只要一种哈希算法出现过碰撞,就会不被推荐成为加密哈希了,只有安全度高的哈希算法才能用作加密哈希。

同时加密哈希其实也能当普通哈希来用,Git版本控制工具就是用SHA-1这个加密哈希算法来做完整性校验的。一般来讲越安全的哈希算法,处理速度也就越慢,所以并不是所有的场合都适合用加密哈希来替代普通哈希。

在密码学领域,有两个算法都是把数据做输入,而输出是一段谁也看不懂的数据。其中一个就是哈希算法,另外一个是加密算法。注意,哈希算法和加密算法是完全不同的。

哈希算法的输出长度是固定的,而加密算法的输出长度是跟数据本身长度直接相关的。

哈希是不可以逆向运算出数据的,而加密算法的输出是要能够逆向运算出数据的。

这里主要是强调加密哈希算法只是被用在加密过程中,但是它本身不是加密算法。

总之,哈希算法有很多种,长度越长的算法基本认为越安全。安全度低的哈希算法被认为是普通哈希算法,主要用来做完整性校验。安全度高的被称为加密哈希算法,会被用在加密算法中。

所谓的高低都是相对概念,例如MD5曾经属于加密哈希,但是目前只能用来做安全校验了。而从2017年开始,SHA-1算法生成的加密证书也会被各大浏览器拒绝了。目前最流行的加密算法是SHA-2,但是跟SHA-1不同,SHA-2 不是一种算法,而是一系列算法的统称,其中就包括咱们之前提过的SHA-256。

  • “祝融万丈拔地起,欲见不见轻烟里”是指?

    01衡山唐代文学家韩愈诗中的“祝融万丈拔地起,欲见不见轻烟里”是指衡山。传说祝融峰是祝融游息之地,他住在衡山,死后又葬在衡山,人们为了纪念他的重大贡献,将衡山的最高峰命名祝融峰...

    生活常识 浏览:504次
  • 高三班级励志语录

    1、哪怕是最没有希望的事情,只要有一个勇敢者去坚持做,到最后就会拥有希望。2、高三班级励志语录有高水平的集体,才有高水平的个人。3、贵在坚持、难在坚持、成在坚持。4、人格的完善是本,财富的确立是末。5...

    经典语录 浏览:909次
  • 女生心爱的网名,甜美心爱的女生名字

    那时花开↘如此青春年华、沫﹏小鑀℡还是、很想你最长的电影被扼殺の啈冨〃钻石气质』仅剩的那分小自尊对你、何止狠做你的天请让~WO沉默秀色可餐 '▲1拈笑颜m︶不知道叫什么$ao-不完的情,或许、...

    个性签名 浏览:791次
  • 精美高级语句摘抄(高端大气上档次的句子)

    01.只要自己是太阳,早晨就一定会到来。02.友不在多,得一人胜百人。03.别着急,你看这年复一年,春光不必趁早,冬霜不会迟到。过去的都会过去,该来的都在路上,一切都是刚刚好。04.你错失了夏花绚烂,...

    经典说说 浏览:640次
  • 怎么用手指吹口哨

    很多人不知道怎么用手指吹口哨,下面就来教大家怎么用手指吹口哨。01把手清洗干净02左手或右手拇指与食指并拢03把做好的手型放到嘴唇边上,用舌尖轻轻顶住两个指尖04接下来轻轻吹气就好特别提示用手指吹口哨...

    生活常识 浏览:940次
Copyright © 2012-2024 早安暖心话 All Rights Reserved
一个致力于分享各类精美句子的心情说说语录网站,是您发朋友圈、发微博、发动态的好帮手!