手机版
扫描查看手机站
首页 > 文章 > 加密世界 > 正文

哈希函数是什么意思?哈希函数应用在区块链的哪些地方?

时间:2025-07-03 11:16:09来源:525游

传说,在人类成功打造出第一台超级智能电脑之时,决定做一个小测验,来试试看这台超级电脑的能耐到底能到多少?实验的设计很简单:让超级电脑计算圆周率是多少。于是,在人们还没反应出来的一瞬间,这台超能电脑已经攻占整个地球,然后对外太空发动了战争,征服整个银河系,把整个可知的宇宙空间变成了巨大的超能电脑,最后花上了无尽的时间,只为了计算出人类给它的这个问题:圆周率。

这是我在阅读人类大历史这本书中读到的一篇故事,原文讨论的内容是算法程序对于人类的威胁;那些不断产生出来并且持续的在优化、改进,声称用以改善人类生活的算法软件,既使一开始创作者本身是完全出于良好善意,或是学术研究而建立的系统,最终仍可能会完全失控的造成毁灭性的结果。这个故事让我想起了Bitcoin等加密货币的挖矿程序算法,在过去一段时间以来对我们生活的冲击影响。还记得2017年加密货币正夯时,全球的挖矿热潮引爆的全民抢电疯,当时就有媒体报导指出,加密货币的挖矿机器将会导致社会大众无电可用,甚至有人传言,那年夏天的几次台电临时跳电事件,就是太多人在挖比特币造成的。

这篇文章,就是要来谈谈比特币挖矿背后的那个算法:加密哈希函数。

哈希函数是什么意思?

哈希函数指将哈希表中元素的关键键值映射为元素存储位置的函数。

一般的线性表,树中,记录在结构中的相对位置是随机的,即和记录的关键字之间不存在确定的关系,因此,在结构中查找记录时需进行一系列和关键字的比较。这一类查找方法建立在“比较“的基础上,查找的效率依赖于查找过程中所进行的比较次数。 理想的情况是能直接找到需要的记录,因此必须在记录的存储位置和它的关键字之间建立一个确定的对应关系f,使每个关键字和结构中一个唯一的存储位置相对应。

哈希函数是什么意思?哈希函数应用在区块链的哪些地方?

哈希函数应用在区块链的哪些地方?

1. 区块链透过哈希函数的结果,将数据串联成为一条难以篡改的连接

2. 比特币、以太币、瑞波币等电子加密货币(题外话,有人说要正名为密码货币),透过哈希函数产生钱包地址

3. 在加密货币挖矿(Mining)的世界,使用Hash Rate: TH/s(trillions of hashes per second)来计算区块链 network的运算能力

4. Bitcoin透过调整哈希函数的难度,控制整个Bitcoin network平均每10分钟产生一个block内存块。

那我们就开始来了解哈希函数算法吧

首先,哈希函数具有下列两项特点:

1. 无论传入(input)哈希函数的数据量大小,哈希函数回传的数据长度都是固定的相同的input,回传

2. 相同的output;不同的input,回传不同的output;

换句话说,哈希函数的回传结果(称之为hash value),是一个长度一致,但是数据内容却是独一无二(unique)的数值。所以,如果看到两个完全不一样的”hash value”,我们就可以推断其原始的input一定是不一样的;反之,两个相同的hash value,其原本的input值则会是一模一样的。

我们可以用Python内置的SHA-256 Hash Algorithm,展示一下上述的哈希函数特性

import hashlib
x1=”my 1st Bitcoin”.encode()
y1=hashlib.sha256(x1).hexdigest()
x2=”I am not Satoshi Nakamoto”.encode()
y2=hashlib.sha256(x2).hexdigest()
print(f’y1= {y1}’)
print(f’y2= {y2}’)
print(f’y1 include {len(y1)} words’)
print(f’y2 include {len(y2)} words’)

哈希函数是什么意思?哈希函数应用在区块链的哪些地方?

如果尚未安装Python,可以利用下面这个网址试试,看看将my 1st Bitcoin Hash后的值是不是和上图用Python跑出来的值(y1=后面的那串)是一样的:

https://anders.com/区块链/hash.html

加密哈希函数是哈希函数于密码学上的一项应用,上述的SHA-256就是一个加密哈希函数的实作产品。

哈希函数还有另一项特点:one-way(单向)function

以上述的Python程序为例,在已知input值=”my 1st Bitcoin”,透过sha256 function,可以快速的算出hash value=”a5e4c0673fcedff2bc2174123e97b511d5d17f4317869e7bd60d0a6d3d7fa1c6”;但反过来说,我们想从”a5e4c0673fcedff2bc2174123e97b511d5d17f4317869e7bd60d0a6d3d7fa1c6”这一串数据中反推出input的值:”my 1st Bitcoin”,唯一的方式是透过暴力解法,也就是不断地丢字串给sha256 function,直到得到hash value是一样时,也就是传入的input字串为”my 1st Bitcoin”时,才能得到答案。各位可以想像这猜中的机率是多低?如果你能一猜就中,那你也不用在这研究内存块链了,直接去买乐透比较快。

区块链透过上述哈希函数的三个特性,构架起了内存块链中的数据,只要一经写入就无法修改的独特功能。

各位可以到下面这个网址体验区块链如何透过哈希函数,紧密的连接起每一个Block内存块,并且坚固地保障了已经建立完成的Block区块,其内容是难以被窜改的。

https://anders.com/区块链/区块链.html

Base58编码

在文章前头,我们曾提到过哈希函数应用在加密货币钱包地址的例子,你可能在一些网站或Blog上,看到过这些乱码数字。实际应用上,部落客或是卖家,会提供一组很像乱码的Bitcoin addresses,让你可以支付比特币给对方;Bitcoin addresses,看起来似乎是一堆英数字的随机编码,但其中也是有特殊的设计:所有的Bitcoin addresses都是使用Base58进行编码。

解释Base58前,先来看看比较常见的,例如已经应用在Email上的电脑编码:Base64。Base64编码包含了26个小写英文字母、26个大写英文字母、10个阿拉伯数字(0~9),和两个特殊字元(+和 — )。

Base58是Base64的子集合,提供一个较高可读性、和较容易发现和防范错误的编码格式,因此广为众多加密货币所使用。Base58剔除了容易辨识错误、或是在某些字体格式看起来十分类似的字元:数字0,大写的英文字母O,小写的英文字母l、大写的英文字母I,并且移除了特殊字元(+和 — )。换句话说,Base58就是包含了大、小写英文字母,和阿拉伯数字,但移除了四个字元(0,O,l,I)的集合:

Bitcoin’s Base58 alphabet:

123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz

Hashing Power

最后,如果对于Bitcoin Network hashing power有兴趣的读者,可以到下面这个网址查看Bitcoin网络的hash rate变化:

https://www.区块链.com/charts/hash-rate

粗略估算,Bitcoin network整体的hashing power,从2009年一秒钟不到一个MegaHash(MH/sec),如今一秒钟已经超过40个ExaHash(EH/sec),光用表面数字计算,成长幅度超过40兆。

HashPower的单位换算可参考下列网址

https://coinguides.org/hashpower-converter-calculator/

OK,我们已经透过两篇文章对内存块链有ㄧ定程度的基础了解了,该是动手写一个区块链程序的时候了。

在进入下一篇文章进行开发前,请各位先确定电脑的开发环境已经安装好下列Python版本和相关modules

· Python 3.6+
· flask 0.12.2
· requests 2.18.4

我另外使用了两个flask module,以建立表单和画面

· flask-wtf
· flask-bootstrap

上述modules皆可透过PIP安装

· pip install flask
· pip install requests
· pip install flask-wtf
· pip install flask-bootstrap

那,就先请各位准备好Python环境啦。

以上就是哈希函数是什么意思?哈希函数应用在区块链的哪些地方?的详细内容,更多关于哈希函数应用介绍的资料请关其它相关文章!


DGCX交易所官网的介绍,DGCX交易所官网地址登录入口 王者荣耀被恶意绑定实名认证怎么修改(王者荣耀被恶意绑定身份证怎么修改实名认证) ZT币前景怎么样?ZT币未来价值和前景分析 问道套装属性怎么激活(问道套装激活条件) 冰原守卫者蛛丝布怎么获得(冰原守卫者wiki) 在国内怎么买比特币最安全?如何购买比特币教程 诛仙手游伏龙鼎怎么获得(诛仙隐藏任务伏龙鼎怎么做) 燃烧意志登场的女性角色(航海王燃烧意志女性角色排行) 最简单的部署MetaMask(小狐狸钱包)教程 动漫手游有哪些值得一玩(动漫游戏有哪些手游) IPFS/FIL挖矿防爆指南,IPFS/FIL挖矿需要主要哪些坑 LUNC币怎么购买交易?LUNC币买卖交易操作教程 BITGET交易所创始人是谁?BITGET交易所官方资料官网地址入口 蜀门手游商店在哪(蜀门手游在哪里交易) 问道手游结拜在哪(问道手游中结拜有什么好处) bitpie比特派钱包更新教程 王者荣耀怎么设置不让别人送礼物(王者荣耀怎么设置不接受礼物) OKB币值得投资吗?OKB币未来能涨到多少2025年价格预测 dnf手游韩服像素武器装扮怎么获得(dnf手游韩服宣传片) 时空猎人冰魄技能搭配(时空猎人冰魄刷图技能搭配) 梦幻西游神秘委托信怎么获得(梦幻西游神秘委托能得到多少钱) 比特派钱包安全吗?是去中心化的钱包吗? bitget交易所排名第几?币圈虚拟货币交易所app十大排名 mysql5.5安装教程:mysql下载与安装图文详解 有什么好玩的单机游戏(单机游戏大作排行榜) 帝国战纪英雄搭配(帝国战纪手游英雄) 金铲铲之战爆爆可以肝出来吗(金铲铲爆率) OKFLY合约地址是什么?OKFLY合约地址有什么用? 中币提现要多长时间?中币网交易所提现人民币教程 YFX在imToken钱包中的使用教程 F2Pool鱼池还能挖吗?F2Pool-全球领先的比特币矿池 和平精英123木头人在哪里玩(吃鸡123木头人) 和平精英创作模式如何传送(和平精英创作模式传送确定在哪) 明日之后茶叶怎么获得(明日之后茶具怎么用) 星露谷物语艾米丽家在哪(星露谷物语艾米丽住在哪里) 欧交易所是OK网易欧交易所吗?欧交易所app官网登录地址入口 打csgo用什么轴键盘(打csgo什么轴键盘最好) LUNC币今日最新价格行情,LUNC币最新消息实时汇率历史走势图 三国志幻想大陆鲁肃最强阵容推荐(三国志幻想大陆鲁肃阵容搭配) 地下城堡3魂之诗沃夫加藏身在哪(地下城堡3沃尔加) 蜀门手游新职业墨韵怎么样(蜀门墨韵玩的人很少) 雷达币一夜之间没有了怎么回事?雷达币会突然消失归零原因 如何买比特币现金/BCH?比特币现金/BCH买卖教程 BT是什么币种?BT币前景及未来价值介绍 问道手游敏水变身卡哪个好(问道敏水吃什么变身卡) 消逝的光芒2瞄准键怎么按(消逝的光芒2操作) TRC20转账要矿工费吗?USDT转一次账需要多少TRX详解 火币网的合约手续费是多少?火币网合约交易的技巧全面解析 消逝的光芒2怎么加速跑(消逝的光芒2视频攻略) 诛仙手游青云平民玩法(诛仙手游青云最强攻略) Lykke交易所是什么?Lykke Exchange全面介绍 香港Crypto交易所有哪些?合规的香港加密货币交易所官网入口 有没有三国养成手游公益服(好玩的三国养成游戏) 有哪些良心卡牌放置类游戏(卡牌放置类游戏推荐) 国内数字货币交易平台有哪些?正规数字货币交易平台排行 币印矿池怎么挖比特币?币印矿池比特币BTC挖矿配置教程 csgo胸章可以在战绩栏显示吗(csgo胸章装备上就不能卖了么) cf安全分不足90怎么办(cf安全分不足80) 仙剑世界3手游哪个职业厉害?仙剑世界3最强新手攻略 imToken钱包和比特派钱包有什么区别? 欧易OKEX永续合约交易有时间限制吗? 暗区突围机密文件在哪刷(暗区突围机密文件在哪刷新概率高) 比特派钱包使用教程:币安智能链BSC通过BITHD使用pancake 梦幻西游改版后69哪个法系最强(梦幻69法系排名) BLCT是什么币种?BLCT币全面介绍 王者荣耀新英雄暃多少钱(王者荣耀新英雄2020到2022) KEX是什么交易所?KEX交易所怎么样? 币安交易所合约怎么开户?币安交易所交易流程 第三课,以博客为例配置strapi后端与next.js对接 Coinlist新项目打新保姆级教程,Coinlist抢币图文教程 有没有免内购充值修仙手游(无需充钱的修仙手游) WBTC是什么币?不到一年市值从400万增长到15亿美金 有什么打怪升级爆装备的手游(打怪升级爆装备的网络游戏) 问道手游福瑞怎么加点(问道手游福瑞加点攻略) 宝可梦大集结为什么一直黑屏(宝可梦大集结为什么一直加载不好) 暗区突围体验服怎么申请(暗区突围体验服资格申请) 维卡币2025中国官网今天最新消息?维卡币官网登录入口 CoinEx交易所究竟怎么样?CoinEx交易所靠谱吗? 我的世界图书管理员怎么生成(我的世界图书管理员生成条件) 什么手机游戏适合休闲娱乐(什么手机游戏休闲又好玩) 如何通过qq查别人英雄联盟ID(怎么用qq号查别人lol的id) 普通人参与chia挖矿,一定要注意的坑有哪些 蜀门手游土豪应该选择什么职业(蜀门手游月赚6000) 狗狗币怎么买?购买狗狗币的 5 个简单步骤 Chia爆火的原因,Chia(奇亚)能不能成为第二个比特币? 在OKEX欧易买币有哪些费用?OKEX欧易网交易手续费怎么算? 原神妖刀怎么获得(妖刀位置) 冰原守卫者佣兵可以帮忙打架吗(冰原守卫者可以交易吗) 王者荣耀全国大赛奖励怎么领取(王者全国大赛有啥用) 王者荣耀镜S26怎么出装(王者荣耀镜的出装以及铭文) imToken钱包2.0ETH钱包备份详细图片教程 王者荣耀露娜启示之音值得买吗(启明露娜出装) DNF充满爱慕的信有什么作用(dnf2021充满爱慕的信) 有什么游戏不用充钱就可以玩(什么游戏不用充钱就可以赚钱) 金铲铲之战暗星变异阵容怎么玩 暗星变异阵容攻略 角色扮演类多人游戏哪一款良心(角色扮演的游戏推荐) 宝可梦传说阿尔宙斯卡蒂狗在哪(神奇宝贝卡阿尔宙斯) 如何查询虚拟货币交易所的持仓数据?加密货币交易所资产结构安全性分析 trx币是什么币?trx币前景和价值分析 比特币钱包私钥在哪查看?比特派钱包查看私钥方法

热门文章

推荐专题

更多>>

游戏推荐

更多>>