简单理解“哈希算法”

【本文由赞我(zaneds.com)独家冠名】

 计算机密码学对区块链技术来说可谓是重中之重,我们在阅读各种区块链项目的白皮书或者区块链相关书籍中,也多少会提及XX算法,如哈希算法和非对称算法,但是算法到底是怎样一种存在?在区块链技术中又解决了哪些问题呢?今天就带来一次计算机密码学的算法之旅--哈希算法

 01

哈希算法一般指SHA家族。SHA是什么?英文全称是Secure Hash Algorithm,即安全散列算法。能计算出一个数字消息所能对应的固定长度字符串的算法。且如果输入的数据不同,他们能对应的不同字符串的机率很高。注意,这里并不是绝对不同。

通过这个定义可以看出哈希算法的特性。第一,输入是可以任意长的字符;第二,输出是固定长度的字符串;第三,函数的计算过程是有效率的。简单的说,就是通过一种方法,可以将任意输入的字符串计算出一段固定长度的字符串。根据这种方法,哪怕数据发生微小的变化,重新计算后的哈希值也会和之前的不一样。而且计算出的来的结算,是无法再通过一个算法还原出原始数据的,即是单向的。故这种算法适合于身份验证的场合,由于哈希值能起到一个类似身份证号的作用,因此可以用于判断数据的完整性。

由于哈希算法的输出值是固定的,而原始数据是多种多样的,所以理论是会存在不同的原始输出输入同一种哈希值的可能。但是这种情况只有在原始数据的数量极其庞大的时候才会出现。例如邮件系统的坑垃圾邮件算法,为了解决这种问题,对邮件地址进行多种哈希计算,将计算出来的值联合起来判断是否存在某个邮件地址,即布隆过滤器的原理。此原理在比特币中有应用。

02

那么在区块链中哈希算法有哪些呢?主要是区块哈希和梅克尔树

区块链是链的结构,而且无法篡改,那是怎么实现的呢?在区块链技术中,对区块头进行了哈希计算,得出某个区块的哈希值,用这个哈希值唯一确定某一个区块,即给这区块确定了一个身份证ID,区块之间通过这个身份ID串联,即区块生成的区块哈希值将成为下一个区块的重要标记,这样每一个新生成的区块的区块头都包含了前一个区块的哈希值,这就使得从创世块到当前区块链接在一起,形成了一条长链。由此这样的区块链结构也使得区块链数据难以篡改,这只是其一。

 03

区块链是如何证明数据完整性,如何保证交易不被篡改呢?这就要说到哈希的另一应用,交易哈希-梅克尔树。区块中的交易记录被一个成为梅克尔树的数据结构来进行哈希值计算和存储,但是只有哈希值记录在区块的哈希值中。

举个例子,一个合同有N页,当我们签订合同的时候,会在每一页都盖章,但是盖的章都是一样的,如果其中一页被替换被修改样式无法防止的。但是如果我们盖章数字章,即给每一个的数字印章是前一页加本页内容加一起使用哈希算法生成哈希值,即N页的数字章=HASH(N—1的数字章+N页内容),这样的话,如果对第一页的内容篡改,那本页的哈希值肯定和本页的数字章不再相符,且之后的也是如此。这就是默克尔树的优势。第一我们可以知道信息是否被篡改,第二我们还能知道第几块信息被篡改。

比特币是分布式的网络结构,它支持一个叫做“简化支付协议(spv)”的协议,一个没有下载完整区块链数据的节点,也能通过向其他节点索要包括从交易哈希沿默克尔树上溯至链头处的跟哈希的哈希序列,以此来快速确认交易输出的正确性。

04

简单总结下,哈希算法即通过一定的函数计算过程,将任意长度的字符转换成固定长度的字符串,而且此种算法是不可逆的,即单向的。区块链中的哈希算法应用主要是区块哈希和梅克尔树;区块哈希即对区块头部进行了哈希算法,确定上一个哈希块的地址。区块链的交易记录通过哈希计算后存储为树状的数据结构,即梅克尔树。区块链的不可篡改和数据的完整性基本是通过以上两种计算机技术方法实现的。由此可见计算机密码算法在区块链中的应用是非常重要的。

好了,今天带大家了解了下什么是哈希算法以及哈希算法在区块链技术中的应用,大家也了解了哈希算法在区块链中解决了哪些问题。关于非对称算法,敬请期待后续文章。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,716评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,558评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,431评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,127评论 0 209
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,511评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,692评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,915评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,664评论 0 202
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,412评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,616评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,105评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,424评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,098评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,096评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,869评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,748评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,641评论 2 271