1. 如何创建和签署以太坊交易
交易
区块链交易的行为遵循不同的规则集
由于公共区块链分布式和无需许可的性质,任何人都可以签署交易并将其广播到网络。
根据区块链的不同,交易者将被收取一定的交易费用,交易费用取决于用户的需求而不是交易中资产的价值。
区块链交易无需任何中央机构的验证。仅需使用与其区块链相对应的数字签名算法(DSA)使用私钥对其进行签名。
一旦一笔交易被签名,广播到网络中并被挖掘到网络中成功的区块中,就无法恢复交易。
以太坊交易结构
以太坊交易的数据结构:交易0.1个ETH
{这些数据与交易内容无关,与交易的执行方式有关,这是由于在以太坊中发送交易中,您必须定义一些其他参数来告诉矿工如何处理您的交易。交易数据结构有2个属性设计"gas": "gasPrice","gasLimit"。
"gasPrice": 单位为Gwei, 为 1/1000个eth,表示交易费用
"gasLimit": 交易允许使用的最大gas费用。
这2个值通常由钱包提供商自动填写。
除此之外还需要指定在哪个以太坊网络上执行交易(chainId): 1表示以太坊主网。
在开发时,通常会在本地以及测试网络上进行测试,通过测试网络发放的测试ETH进行交易以避免经济损失。在测试完成后再进入主网交易。
另外,如果需要提交一些其它数据,可以用"data"和"nonce"作为事务的一部分附加。
A nonce(仅使用1次的数字)是以太坊网络用于跟踪交易的数值,有助于避免网络中的双重支出以及重放攻击。
以太坊交易签名
以太坊交易会涉及ECDSA算法,以Javascript代码为例,使用流行的ethers.js来调用ECDSA算法进行交易签名。
可以使用在线使用程序Composer将已签名的交易传递到以太坊网络。这种做法被称为”离线签名“。离线签名对于诸如状态通道之类的应用程序特别有用,这些通道是跟踪两个帐户之间余额的智能合约,并且在提交已签名的交易后就可以转移资金。脱机签名也是去中心化交易所(DEXes)中的一种常见做法。
也可以使用在线钱包通过以太坊账户创建签名验证和广播。
使用Portis,您可以签署交易以与加油站网络(GSN)进行交互。
链乔教育在线旗下学硕创新区块链技术工作站是中国教育部学校规划建设发展中心开展的“智慧学习工场2020-学硕创新工作站 ”唯一获准的“区块链技术专业”试点工作站。专业站立足为学生提供多样化成长路径,推进专业学位研究生产学研结合培养模式改革,构建应用型、复合型人才培养体系。
2. “区块链养猫”是个什么怎么玩(非常详尽的教程)
这一次,喵星人又在区块链世界meow了一波高潮。
几天时间里,"区块链养猫"已经成为币圈的热点。
CryptoKitties 加密猫是第一个使用区块链技术,运行在以太坊网络的虚拟宠物游戏。
她的出现具有了某种历史意义,目前已经成为了以太坊区块链上最受欢迎的项目,一度占据了整个以太坊 20% 的流量。市场的交易额已达几百万美元,而且这个数据仍在快速增长着...
这个概念很简单。你使用以太币购买一只猫咪,每个猫咪都是独一无二的,只要你不卖,它100% 由你所有,不能被复制,不能被销毁。
好玩之处在于你可以去市场找猫配种,或者在买一只猫咪,两两相配,生出的小猫就属于你的啦。
而每个小猫都是从父母那里提取一定序列进行组合,无论从毛色、斑纹、瞳孔、还是发型、表情、尾巴等特征都是随机的,总计有40亿种变化的可能。然后可以把你的猫咪在市场上卖出,价格你自己定。
还有一点,每隔15分钟,就会诞生1个gen 0 的创世猫,它的价格相当于最新售卖出去的5只猫均价的基础上再增加50%。当然创世猫是受热捧的,毕竟人家是virgin嘛,生小猫速度是最快的。
这是不是有点像我们鸡生蛋,蛋生鸡,子子孙孙无穷匮也的故事呢?
当然生孩子是要靠时间的。
一直小猫的诞生从快快快到慢~慢~慢~,差距从一分钟到一个星期不等。
如果你的猫咪生产的时间越短,越有利。这样可以把新生的加密猫快速卖出,并继续繁殖。这也意味着收入的增加。
生的越多,猫咪的cooldowns冷却时间就越长,生育速度也会降下来。
还有一个好玩的是,生小猫咪是一个复杂的繁育系统和随机的,意味着总有些变异属性 (cattributes)出现其中,这些就变成了收藏品或者紧俏品。
1. 进入加密猫官网: cryptokitties.co 点击sign in 会跳到注册页面。需要你在chrome或者firefox浏览器上安装以太坊轻钱包 MetaMask 插件。(这过程是要可学上的, 这里有三种方式 ,怎么顺手怎么来吧,客官。 密码:1rjo )
2. 点击 Mertamask 插件进行安装。
3. 接受条款,输入密码。
4. 生成的12个英文单词密码你可要一定一定记住了。连同jason文件一起保存好。
5. 然后钱包创建完成啦。进入 cryptokitties.co 网站就可以看到你的账户了,设置姓名邮箱等。
方式一:如果你的其他以太坊钱包里有ETH,比如imtoken,可以直接转账到你的加密猫地址即可。
方式二:在这篇文章提到过的 3个场外比特币交易所比较 的其中两个: Coincola 和 bitcoinworld 均支持ETH交易,也可以直接上面直接转过去。
方式三:是Matamask推荐的coinbase,不过显示 US only.
1. 去marketplace寻找你喜欢的猫咪吧(如下图)。
2. 看中之后,点击buy now.
详情页显示了猫的详细信息,编号,价格趋势图(1天或2天随着时间价格持续增加或减少),现在购买的价格,以及生小猫的冷却时间等。
3. 点击 ok,buy this kitty后, matamask会弹出显示详细的预计花费。如果出现没成绩,可能你的矿工费给的不够,或者猫咪卖出,多试试吧。max transaction fee是显示最大的交易费,一般不会到的。summit后就等待交易完成吧。取消交易,点击reject.
交易过程中可以点击该笔交易进入https://etherscan.io查看详情。或者在网站右侧的类似心电图的图标查看历史交易信息。
4. 交易成功!恭喜你,拥有了第一个虚拟猫咪啦。怎么赚更多呢?
一种方式,生。
两两配对。生小猫也是要交交易费的。生的速度要看父母的速度。
Breed kitty 生小猫;
Sell kitty 卖掉小猫
Gift kitty 送小猫给朋友
另一种方式是,出租。
Sire to the public,意思是把你的猫咪当做公猫租出去,设置初始价格和结束价格和日期,充当精子库吧。
sire to my kitties,意思是让你的两个猫XXOO生小猫。
最终的方式是卖。
小猫生出啦,邮件会通知你。可以选择卖出,设置价格就可以出售啦。
如果有人买走,也会邮件通知你。
好啦,让我们愉快的做个猫奴吧~
原文: http://li-wu.net/how-to-cryptokitties.html
3. shib提错到了heco怎么找回
比特派钱包导出私钥,导入到火币钱包的heco链,查到shib在heco的合约地址,添加资产里面填进去就在里面。
HECOBSCETH的充值地址都是0x开头,很多朋友着急或者手误,容易复制错地址,导致BSC链上的代币被错转到了HECO或者ETH链上。这种情况怎么处理呢,往下面看!
首先区分一下被转错的链和平台,比如你本来要转BSC链上的USDT到交易所,但是不小心地址复制成了交易所ETH链的USDT充值地址也就是ERC20的充值地址,这种情况自己没有办法去找回币,需要联系平台的在线客服,走退回流程,给你退回到你提现的地址。
如果你是转到链上,你从交易所提BSC链上的USDT,地址你不小心写成了ETH链上的地址,你在自己的BSC钱包怎么都找不到USDT,但是链上显示到账了,这个时候,这个币去了哪里呢?这个币就在和你ETH地址相同的BSC链上钱包里,你只需要把ETH链上钱包的助记词导入BSC链上,就能看到USDT,如果看不到,就在钱包里添加一下该链上USDT的合约。
下面是转错到链上操作的实例:
1、3月份这位朋友找到我,说他转错了链,他要把USDT转去BSC链上,但是从抹茶交易所提币的时候,走了ERC20的链。
2、他的币怎么能找到呢,就是把BSC钱包的助记词导入ETH链上钱包。
备注一下:BSC链在一些平台的显示是BEP20;例子已征求当事人同意;
4. imtoken钱包转账失败怎么回事
imtoken钱包转账失败怎么回事,相信很多人在使用imtoken钱包的时候经常的会碰到转账失败的情况,不少人不知道这个情况是怎么引起的,下面跟着小编一起来看看吧。
imtoken钱包转账失败怎么回事
Outofgas(Gas不足)
打个通俗易懂的比喻吧,就像你开车必须要有汽油一样,你在以太坊上转账也需要有Gas。开车≈转账,汽油≈Gas。如果你要从A地驱车前往B地,按照实时的交通情况,你需要消耗200升汽油。但你为这次行程只准备了150升汽油,那是派拦否能到达B地呢?在现实生活中,大家肯定都知道,你一定是到不了的。同时虽然你没到达B地,但是你的汽油却已经消耗了。
那么回到区块链的世界,也是同样的道理。如果你要进行一笔转账,就要为这笔转账设置一个Gas。如果你设置的过低,就会出现「汽车」没到达目的地就没「油」的情况,即交易失败。失败原因就是outofgas(汽油不足)。同时,又因为矿工们已经进行了打绝羡首包的操作,但在打包过程中发现Gas不足,导致这笔交易打包失败了。矿工费仍然会被扣除,但这些矿工费都是由矿工们收取的,imToken并不收你一分钱。
BadInstruction(指令错误)
Badinstruction字面意思是「指令错误」。出现这种提示的原因,大概率是因为智能合约的代码本身就存在逻辑问题,从而导致合约在执行的过程中,出现「指令错误」。这就像一台坏了的机器,你输入一个指令,机器是不能正常运作的。这时候,我们该找谁解决呢?当然是智能合约的创建方,去修复这台「坏了的机器」。另外转账的矿工费仍然会被矿工收走。
Reverted(回退)
以太坊上包含两类账户,普通账户和合约账户。普通账户是由用户通过私钥控制,而合约账户是由部署在以太坊上的智能合约控制。
那么,reverted是什么情况呢?reverted其实是一个函数,用于立即中止合约的执行,并且把状态回滚。虽然是智能合约,比一般的合约更「聪明」,但是有些合约在执行的过程中还是会「犯错」的。
这听起来是不是过于抽象,让我们打个简单的比方。出现reverted的一种可能情况:你的合约规定,当你输入一块钱,你可以得到一杯喜茶并数。但是这个合约并没有检查库存里是否有足够的喜茶。当店里没有喜茶库存的时候,后面来的人,即使它输入一块钱,也不能得到喜茶。这时候,你原本的函数-即输入一块钱就会得到一杯喜茶的函数就会失败,它会发出错误的信息并回滚到当前的交易状态。
看到这里,想必大家也已经明白了,出现badinstruction和reverted,都是因为智能合约的问题,所以建议大家直接去找合约的创建者,也就是项目方。
5. 以太坊是如何挖矿的
以太坊的代币是通过采矿过程中产生的,每块采矿率为 5 个以太币。以太坊的采矿过程几乎与比特币相同,对于每一笔交易,矿工都可以使用计算机通过散列函数运行该块的唯一标题元数据,反复,快速地猜出答案,直到其中一人获胜。
许多新用户认为,采矿的唯一目的是以不需要中央发行人的方式生成醚(参见我们的指南“ 什么是以太? ”)。这是真的。以太坊的代币是通过采矿过程中产生的,每块采矿率为 5 个以太币。但是,采矿还有至少同样重要的作用。通常,银行负责保持交易的准确记录。他们确保资金不是凭空创造的,用户不会多次欺骗和花钱。不过,区块链引入了一种全新的记录保存方式,整个网络而不是中介,验证交易并将其添加到公共分类账。
Ethereum Mining
尽管“无信任”或“信任最小化”货币体系是目标,但仍有人需要确保财务记录的安全,确保没有人作弊。采矿是使分散记录成为可能的创新之一。矿工们在防止欺诈行为(特别是醚的双重支出)方面达成了关于交易历史的共识 – 这是一个有趣的问题,在分散化的货币未在工作区块链之前解决。虽然以太坊正在研究其他方法来就交易的有效性达成共识,但采矿目前将平台保持在一起。
挖矿如何工作
今天,以太坊的采矿过程几乎与比特币相同。对于每一笔交易,矿工都可以使用计算机反复,快速地猜出答案,直到其中一人获胜。更具体地说,矿工将通过散列函数(它将返回一个固定长度,乱序的数字和字母串,它看起来是随机的)运行该块的唯一标题元数据(包括时间戳和软件版本),只改变’nonce 值’ ,这会影响结果散列值。
如果矿工发现与当前目标相匹配的散列,矿工将被授予乙醚并在整个网络上广播该块,以便每个节点验证并添加到他们自己的分类账副本中。如果矿工 B 找到散列,矿工 A 将停止对当前块的工作,并为下一个块重复该过程。矿工很难在这场比赛中作弊。没有办法伪造这项工作,并拿出正确的谜题答案。这就是为什么解谜方法被称为“工作证明”。
另一方面,其他人几乎没有时间验证散列值是否正确,这正是每个节点所做的。大约每 12-15 秒,一名矿工发现一块石块。如果矿工开始比这更快或更慢地解决谜题,算法会自动重新调整问题的难度,以便矿工回弹到大约 12 秒钟的解决时间。
矿工们随机赚取这些乙醚,他们的盈利能力取决于运气和他们投入的计算能力。以太坊使用的具体工作量验证算法被称为’ethash’,旨在需要更多的内存,使得使用昂贵的 ASIC 难以开采 – 特殊的采矿芯片,现在是唯一可以盈利的比特币开采方式。
从某种意义上讲,ethash 可能已经成功实现了这一目的,因为专用 ASIC 不可用于以太坊(至少目前还没有)。此外,由于以太坊旨在从工作证明挖掘转变为“股权证明”(我们将在下面讨论),购买 ASIC 可能不是一个明智的选择,因为它可能无法长久证明有用。
转移到股权证明
不过,以太坊可能永远不需要矿工。开发人员计划放弃工作证明,即网络当前使用的算法来确定哪些交易是有效的,并保护其免受篡改,以支持股权证明,网络由代币所有者担保。如果并且当该算法推出时,股权证明可以成为实现分布式共识的一种手段,而该共识使用更少的资源。
6. 以太坊是什么丨以太坊开发入门指南
以太坊是什么丨以太坊开发入门指南
很多同学已经跃跃欲试投入到区块链开发队伍当中来,可是又感觉无从下手,本文将基于以太坊平台,以通俗的方式介绍以太坊开发中涉及的各晦涩的概念,轻松带大家入门。
以太坊是什么
以太坊(Ethereum)是一个建立在区块链技术之上, 去中心化应用平台。它允许任何人在平台中建立和使用通过区块链技术运行的去中心化应用。
对这句话不理解的同学,姑且可以理解为以太坊是区块链里的Android,它是一个开发平台,让我们就可以像基于Android Framework一样基于区块链技术写应用。
在没有以太坊之前,写区块链应用是这样的:拷贝一份比特币代码,然后去改底层代码如加密算法,共识机制,网络协议等等(很多山寨币就是这样,改改就出来一个新币)。
以太坊平台对底层区块链技术进行了封装,让区块链应用开发者可以直接基于以太坊平台进行开发,开发者只要专注于应用本身的开发,从而大大降低了难度。
目前围绕以太坊已经形成了一个较为完善的开发生态圈:有社区的支持,有很多开发框架、工具可以选择。
智能合约
什么是智能合约
以太坊上的程序称之为智能合约, 它是代码和数据(状态)的集合。
智能合约可以理解为在区块链上可以自动执行的(由事件驱动的)、以代码形式编写的合同(特殊的交易)。
在比特币脚本中,我们讲到过比特币的交易是可以编程的,但是比特币脚本有很多的限制,能够编写的程序也有限,而以太坊则更加完备(在计算机科学术语中,称它为是“图灵完备的”),让我们就像使用任何高级语言一样来编写几乎可以做任何事情的程序(智能合约)。
智能合约非常适合对信任、安全和持久性要求较高的应用场景,比如:数字货币、数字资产、投票、保险、金融应用、预测市场、产权所有权管理、物联网、点对点交易等等。
目前除数字货币之外,真正落地的应用还不多(就像移动平台刚开始出来一样),相信1到3年内,各种杀手级会慢慢出现。
编程语言:Solidity
智能合约的默认的编程语言是Solidity,文件扩展名以.sol结尾。
Solidity是和JavaScript相似的语言,用它来开发合约并编译成以太坊虚拟机字节代码。
还有长像Python的智能合约开发语言:Serpent,不过建议大家还是使用Solidity。
Browser-Solidity是一个浏览器的Solidity IDE, 大家可以点进去看看,以后我们更多文章介绍Solidity这个语言。
运行环境:EVM
EVM(Ethereum Virtual Machine)以太坊虚拟机是以太坊中智能合约的运行环境。
Solidity之于EVM,就像之于跟JVM的关系一样,这样大家就容易理解了。
以太坊虚拟机是一个隔离的环境,在EVM内部运行的代码不能跟外部有联系。
而EVM运行在以太坊节点上,当我们把合约部署到以太坊网络上之后,合约就可以在以太坊网络中运行了。
合约的编译
以太坊虚拟机上运行的是合约的字节码形式,需要我们在部署之前先对合约进行编译,可以选择Browser-Solidity Web IDE或solc编译器。
合约的部署
在以太坊上开发应用时,常常要使用到以太坊客户端(钱包)。平时我们在开发中,一般不接触到客户端或钱包的概念,它是什么呢?
以太坊客户端(钱包)
以太坊客户端,其实我们可以把它理解为一个开发者工具,它提供账户管理、挖矿、转账、智能合约的部署和执行等等功能。
EVM是由以太坊客户端提供的。
Geth是典型的开发以太坊时使用的客户端,基于Go语言开发。 Geth提供了一个交互式命令控制台,通过命令控制台中包含了以太坊的各种功能(API)。Geth的使用我们之后会有文章介绍,这里大家先有个概念。
Geth控制台和Chrome浏览器开发者工具里的面的控制台是类似,不过是跑在终端里。
相对于Geth,Mist则是图形化操作界面的以太坊客户端。
如何部署
智能合约的部署是指把合约字节码发布到区块链上,并使用一个特定的地址来标示这个合约,这个地址称为合约账户。
以太坊中有两类账户:
· 外部账户
该类账户被私钥控制(由人控制),没有关联任何代码。
· 合约账户
该类账户被它们的合约代码控制且有代码与之关联。
和比特币使用UTXO的设计不一样,以太坊使用更为简单的账户概念。
两类账户对于EVM来说是一样的。
外部账户与合约账户的区别和关系是这样的:一个外部账户可以通过创建和用自己的私钥来对交易进行签名,来发送消息给另一个外部账户或合约账户。
在两个外部账户之间传送消息是价值转移的过程。但从外部账户到合约账户的消息会激活合约账户的代码,允许它执行各种动作(比如转移代币,写入内部存储,挖出一个新代币,执行一些运算,创建一个新的合约等等)。
只有当外部账户发出指令时,合同账户才会执行相应的操作。
合约部署就是将编译好的合约字节码通过外部账号发送交易的形式部署到以太坊区块链上(由实际矿工出块之后,才真正部署成功)。
运行
合约部署之后,当需要调用这个智能合约的方法时只需要向这个合约账户发送消息(交易)即可,通过消息触发后智能合约的代码就会在EVM中执行了。
Gas
和云计算相似,占用区块链的资源(不管是简单的转账交易,还是合约的部署和执行)同样需要付出相应的费用(天下没有免费的午餐对不对!)。
以太坊上用Gas机制来计费,Gas也可以认为是一个工作量单位,智能合约越复杂(计算步骤的数量和类型,占用的内存等),用来完成运行就需要越多Gas。
任何特定的合约所需的运行合约的Gas数量是固定的,由合约的复杂度决定。
而Gas价格由运行合约的人在提交运行合约请求的时候规定,以确定他愿意为这次交易愿意付出的费用:Gas价格(用以太币计价) * Gas数量。
Gas的目的是限制执行交易所需的工作量,同时为执行支付费用。当EVM执行交易时,Gas将按照特定规则被逐渐消耗,无论执行到什么位置,一旦Gas被耗尽,将会触发异常。当前调用帧所做的所有状态修改都将被回滚, 如果执行结束还有Gas剩余,这些Gas将被返还给发送账户。
如果没有这个限制,就会有人写出无法停止(如:死循环)的合约来阻塞网络。
因此实际上(把前面的内容串起来),我们需要一个有以太币余额的外部账户,来发起一个交易(普通交易或部署、运行一个合约),运行时,矿工收取相应的工作量费用。
以太坊网络
有些着急的同学要问了,没有以太币,要怎么进行智能合约的开发?可以选择以下方式:
选择以太坊官网测试网络Testnet
测试网络中,我们可以很容易获得免费的以太币,缺点是需要发很长时间初始化节点。
使用私有链
创建自己的以太币私有测试网络,通常也称为私有链,我们可以用它来作为一个测试环境来开发、调试和测试智能合约。
通过上面提到的Geth很容易就可以创建一个属于自己的测试网络,以太币想挖多少挖多少,也免去了同步正式网络的整个区块链数据。
使用开发者网络(模式)
相比私有链,开发者网络(模式)下,会自动分配一个有大量余额的开发者账户给我们使用。
使用模拟环境
另一个创建测试网络的方法是使用testrpc,testrpc是在本地使用内存模拟的一个以太坊环境,对于开发调试来说,更方便快捷。而且testrpc可以在启动时帮我们创建10个存有资金的测试账户。
进行合约开发时,可以在testrpc中测试通过后,再部署到Geth节点中去。
更新:testrpc 现在已经并入到Truffle 开发框架中,现在名字是Ganache CLI。
Dapp:去中心化的应用程序
以太坊社区把基于智能合约的应用称为去中心化的应用程序(DecentralizedApp)。如果我们把区块链理解为一个不可篡改的数据库,智能合约理解为和数据库打交道的程序,那就很容易理解Dapp了,一个Dapp不单单有智能合约,比如还需要有一个友好的用户界面和其他的东西。
Truffle
Truffle是Dapp开发框架,他可以帮我们处理掉大量无关紧要的小事情,让我们可以迅速开始写代码-编译-部署-测试-打包DApp这个流程。
总结
我们现在来总结一下,以太坊是平台,它让我们方便的使用区块链技术开发去中心化的应用,在这个应用中,使用Solidity来编写和区块链交互的智能合约,合约编写好后之后,我们需要用以太坊客户端用一个有余额的账户去部署及运行合约(使用Truffle框架可以更好的帮助我们做这些事情了)。为了开发方便,我们可以用Geth或testrpc来搭建一个测试网络。
注:本文中为了方便大家理解,对一些概念做了类比,有些严格来不是准确,不过我也认为对于初学者,也没有必要把每一个概念掌握的很细致和准确,学习是一个逐步深入的过程,很多时候我们会发现,过一段后,我们会对同一个东西有不一样的理解。