2024-09-10 08:11:21
虽然是个前端开发,但是阻挡不了我八卦各种热门的心。下面简单汇总下一些学习到的概念性东西。
1、区块链技术随比特币诞生,因此先了解比特币概念
2、比特币是什么
(1)、基于分布式网络的数字货币
3、比特系统运行原理
(1)、所有节点都会保存完整账本
(2)、账本保持一致性
4、区块链记账原理
hash函数在区块链技术中有广泛的运用
(1)、哈希函数hash:任何信息hash后会得到一个简短的摘要信息
(2)、hash特点:简化信息、标识信息、隐匿信息、验证信息
(3)、区块链记账会把时间节点的账单信息hash,构成一个区块
(4)、比特币系统约10分钟记账一次,即每个区块生成的时间间隔大约10分钟
(5)、记录下一个账单时,会把上一个区块的hash值和当前账单的信息一起作为原始信息进行hash
(6)、每个区块都包含了之前区块的信息,这些区块组合成了区块链
5、比特币的所有权-非对称加密应用
比特币系统使用了椭圆曲线签名算法,算法的私钥由32个字节随机数组成,通过私钥可以计算出公钥,公钥经过一序列哈希算法和编码算法得到比特币地址,地址也可以理解为公钥的摘要。
(1)、转账是把比特币从一个地址转移到另一个地址
(2)、地址私钥是非对称的关系,私钥经过一系列的运算(其中包含两次hash),就可以得到地址,但是从地址无法得到私钥
(3)、转账成功后广播其他节点,其他节点验证成功后再转发到相邻的节点,广播的信息包含了原始的信息和签名信息
(4)、验证,其他节点验证签名信息是不是付款方用私钥对交易原始信息签名产生的,如果是才记录(再验证有足够余额)
6、比特币如何挖矿
(1)、完成记账的节点可以获得系统给予的一定数量比特币奖励(这个奖励过程也就是比特币的发行过程,因此大家把记账称为挖矿)
(2)、一段时间内只有一人可以记账成功,因此需要收集没有被收集的原始交易信息,检查有没有余额、正确签名
(3)、为了提高记账难度,十分钟左右只有一人可以记账,hash结果需要若干0开头,并且进行hash时引入随机数变量
(4)、随着更多矿工的加入,游戏难度越来越大,计算难度加大,电力损耗等加大,国内电力成本低,中国算力占整个网络的一半以上
(5)、网络中只有最快解密的区块,才会添加到账本中,其他的节点复制,保证账本的唯一性。如果有节点作弊,导致整个网络不通过,则会被丢弃再也不会记录到总账本中。因此所有节点都会遵守比特币系统的共同协议。
【关于区块链会延伸到那些领域的思考】:
由以上的概念可以总结出,区块链技术存在这安全性、唯一性、去中心化。
原则上是可以避免部分信息泄露,让确认方既可以确认你的身份,又无需暴露自己的真是用户信息等。
目前区块链技术集中被运用再比特币,我觉得后续更大的意义应该在需要数据私密性、安全性的领域。
【关于区块链目前发展的瓶颈和局限性思考】:
由于每个节点都参与了整个账本记录活动,难免造成资源的浪费和损耗。以及加大了每个节点的计算难度,后续的发展和普及需要每个节点的硬件提升。
区块链编号是什么意思?——区块链编号,即区块链咨询服务名称及备案编号。区块链没有通用协议,多是独立运作,对区块链进行备案编号,是建立通用协议配套制度的工作之一。
区块编号作用是什么用作是一个分类账本,任何拥有权限的人都可以分享并对其进行确认。
国家互联网信息办公室官网发布公告,披露第一批共197个境内区块链信息服务名称及备案编号。值得注意的是,“备案编号”并不能看做是给区块链披上合法的“黄马甲”,应正确认识“备案编号”的作用。
证券日报在文中指出,不可过度解读“备案编号”的作用。网信办表示,备案仅是对主体区块链信息服务相关情况的登记,不代表对其机构、产品和服务的认可,并强调,任何机构和个人不得用于任何商业目的。
acm明星币现在价格,有名气吗一.项目简介:
Actinium(ACM)是一种基于区块链技术的去中心化货币,旨在将密码带入每个客户的口袋,每个商店,非常安全且易于使用。Actinium是一种闪电网络支持的加密货币,即时交易的手续费近乎为零。同时,具备原子交换功能以及许多其他的第二层解决方案。
二.项目信息(截止2019年9月6日)
·项目编码:ACM
·总量:84,000,000
·流通量:13,516,241
·算法:Lyra2z
·区块时间:2.5分钟
·区块奖励:50ACM
,交易所:CITEX.IO
三.点评
·Zerocash协议使得ACM能够建立专门的ACM匿名交易,用以混淆每一个交易数据,包括交易金额、接发方识别信息等;
·ACM为了实现支付的便捷性,使用先进的闪电技术。
区块链备案号码是什么
备案号是网站是否合法注册经营的标志,可随时到国家工业和信息化部网站备案系统上查询该ICP备案的相关详细信息。
根据《管理规定》要求,区块链信息服务提供者应当在其对外提供服务的互联网站、应用程序等显著位置标明其备案编号。
备案仅是对主体区块链信息服务相关情况的登记,不代表对其机构、产品和服务的认可,任何机构和个人不得用于任何商业目的。网信部门后续将会同各有关部门,依据《管理规定》对备案主体进行监督检查,并督促未备案主体尽快履行备案义务。请尚未履行备案手续的相关机构和个人尽快申请备案。
第四批备案企业地区分布情况:
据备案清单显示,第四批境内区块链信息服务备案项目所在企业,有76家属于北京企业,其余的大部分企业集中在广东、浙江、上海。
梳理发现,第四批名单中共有来自22个省直辖市自治区的企业。其中,北京、广东、上海三家备案企业最多,分别为76家、57家、32家;上海紧随其后为31家,江苏以9家位列第五。
【深度知识】以太坊数据序列化RLP编码/解码原理RLP(RecursiveLengthPrefix),中文翻译过来叫递归长度前缀编码,它是以太坊序列化所采用的编码方式。RLP主要用于以太坊中数据的网络传输和持久化存储。
对象序列化方法有很多种,常见的像JSON编码,但是JSON有个明显的缺点:编码结果比较大。例如有如下的结构:
变量s序列化的结果是{"name":"icattlecoder","sex":"male"},字符串长度35,实际有效数据是icattlecoder和male,共计16个字节,我们可以看到JSON的序列化时引入了太多的冗余信息。假设以太坊采用JSON来序列化,那么本来50GB的区块链可能现在就要100GB,当然实际没这么简单。
所以,以太坊需要设计一种结果更小的编码方法。
RLP编码的定义只处理两类数据:一类是字符串(例如字节数组),一类是列表。字符串指的是一串二进制数据,列表是一个嵌套递归的结构,里面可以包含字符串和列表,例如["cat",["puppy","cow"],"horse",[[]],"pig",[""],"sheep"]就是一个复杂的列表。其他类型的数据需要转成以上的两类,转换的规则不是RLP编码定义的,可以根据自己的规则转换,例如struct可以转成列表,int可以转成二进制(属于字符串一类),以太坊中整数都以大端形式存储。
从RLP编码的名字可以看出它的特点:一个是递归,被编码的数据是递归的结构,编码算法也是递归进行处理的;二是长度前缀,也就是RLP编码都带有一个前缀,这个前缀是跟被编码数据的长度相关的,从下面的编码规则中可以看出这一点。
对于值在[0,127]之间的单个字节,其编码是其本身。
例1:a的编码是97。
如果byte数组长度l=55,编码的结果是数组本身,再加上128+l作为前缀。
例2:空字符串编码是128,即128=128+0。
例3:abc编码结果是131979899,其中131=128+len("abc"),979899依次是abc。
如果数组长度大于55,编码结果第一个是183加数组长度的编码的长度,然后是数组长度的本身的编码,最后是byte数组的编码。
请把上面的规则多读几篇,特别是数组长度的编码的长度。
例4:编码下面这段字符串:
Thelengthofthissentenceismorethan55bytes,IknowitbecauseIpre-designedit
这段字符串共86个字节,而86的编码只需要一个字节,那就是它自己,因此,编码的结果如下:
184868410410132108101110103116104321111023211610410511532115101110116101110991013210511532109111114101321161049711032535332981211161011154432733210711011111932105116329810199971171151013273321121141014510010111510510311010110032105116
其中前三个字节的计算方式如下:
184=183+1,因为数组长度86编码后仅占用一个字节。
86即数组长度86
84是T的编码
例5:编码一个重复1024次"a"的字符串,其结果为:18540979797979797...。
1024按bigendian编码为0040,省略掉前面的零,长度为2,因此185=183+2。
规则1~3定义了byte数组的编码方案,下面介绍列表的编码规则。在此之前,我们先定义列表长度是指子列表编码后的长度之和。
如果列表长度小于55,编码结果第一位是192加列表长度的编码的长度,然后依次连接各子列表的编码。
注意规则4本身是递归定义的。
例6:["abc","def"]的编码结果是200131979899131100101102。
其中abc的编码为131979899,def的编码为131100101102。两个子字符串的编码后总长度是8,因此编码结果第一位计算得出:192+8=200。
如果列表长度超过55,编码结果第一位是247加列表长度的编码长度,然后是列表长度本身的编码,最后依次连接各子列表的编码。
规则5本身也是递归定义的,和规则3相似。
例7:
["Thelengthofthissentenceismorethan55bytes,","IknowitbecauseIpre-designedit"]
的编码结果是:
248881798410410132108101110103116104321111023211610410511532115101110116101110991013210511532109111114101321161049711032535332981211161011154432163733210711011111932105116329810199971171151013273321121141014510010111510510311010110032105116
其中前两个字节的计算方式如下:
248=247+1
88=86+2,在规则3的示例中,长度为86,而在此例中,由于有两个子字符串,每个子字符串本身的长度的编码各占1字节,因此总共占2字节。
第3个字节179依据规则2得出179=128+51
第55个字节163同样依据规则2得出163=128+35
例8:最后我们再来看个稍复杂点的例子以加深理解递归长度前缀,
["abc",["Thelengthofthissentenceismorethan55bytes,","IknowitbecauseIpre-designedit"]]
编码结果是:
24894131979899248881798410410132108101110103116104321111023211610410511532115101110116101110991013210511532109111114101321161049711032535332981211161011154432163733210711011111932105116329810199971171151013273321121141014510010111510510311010110032105116
列表第一项字符串abc根据规则2,编码结果为131979899,长度为4。
列表第二项也是一个列表项:
["Thelengthofthissentenceismorethan55bytes,","IknowitbecauseIpre-designedit"]
根据规则5,结果为
248881798410410132108101110103116104321111023211610410511532115101110116101110991013210511532109111114101321161049711032535332981211161011154432163733210711011111932105116329810199971171151013273321121141014510010111510510311010110032105116
长度为90,因此,整个列表的编码结果第二位是90+4=94,占用1个字节,第一位247+1=248
以上5条就是RPL的全部编码规则。
各语言在具体实现RLP编码时,首先需要将对像映射成byte数组或列表两种形式。以go语言编码struct为例,会将其映射为列表,例如Student这个对象处理成列表["icattlecoder","male"]
如果编码map类型,可以采用以下列表形式:
[["",""],["",""],["",""]]
解码时,首先根据编码结果第一个字节f的大小,执行以下的规则判断:
1.如果f∈[0,128),那么它是一个字节本身。
2.如果f∈[128,184),那么它是一个长度不超过55的byte数组,数组的长度为l=f-128
3.如果f∈[184,192),那么它是一个长度超过55的数组,长度本身的编码长度ll=f-183,然后从第二个字节开始读取长度为ll的bytes,按照BigEndian编码成整数l,l即为数组的长度。
4.如果f∈(192,247],那么它是一个编码后总长度不超过55的列表,列表长度为l=f-192。递归使用规则1~4进行解码。
5.如果f∈(247,256],那么它是编码后长度大于55的列表,其长度本身的编码长度ll=f-247,然后从第二个字节读取长度为ll的bytes,按BigEndian编码成整数l,l即为子列表长度。然后递归根据解码规则进行解码。
以上解释了什么叫递归长度前缀编码,这个名字本身很好的解释了编码规则。
(1)以太坊源码学习—RLP编码()
(2)简单分析RLP编码原理
()