新闻
web3.0系统技术详细介绍与分析
2023-12-17 11:40  浏览:23
web3.0系统技术详细介绍与分析

Web 3.0的纽带作用:

  

  与DAPP浏览器相辅相成的是其底层网络架构Web 3.0,这是和信息互联网系统-176搭建-0206+可电可微-5616时代传统浏览器基于的Web 2.0完全不同的体系架构。***技术,尤其是ETH的出现使Web 3.0成为基于***进行价值传递的基础网络。

  

  从技术架构来看,Web 3.0的体系架构更为复杂,它在传统信息互联网的基础上,增加了价值(Token)的传递。

  

  合约是代码(它的功能)和数据(它的状态)的集合,存在于ETH***的特定地址。合约账户能够在彼此之间传递信息,进行图灵完备的运算。合约依靠被称作ETH虚拟机(EVM)字节代码(ETH特有的二进制格式)上的***运行。

  

  合约很典型地用诸如Solidity等语言写成,然后编译成字节代码上传到***上。

  

  ETH语言

  

  合约依靠被称作ETH虚拟机(EVM)字节代码(ETH特有的二进制格式)上的***运行。然而,合约很典型地用诸如Solidity等语言写成,然后用ETH虚拟机编译器编译成字节代码上传到***。

  

  编译合约

  

  solidity合约的编译可以通过很多机制完成。

  

  通过命令行使用solc编译器。

  

  在geth或eth提供的javascript控制台使用web3.eth.compile.solidity(这仍然需要安装solc编译器)。

  

  在线Solidity实时编译器。

  

  建立solidity合约的Meteor dapp Cosmo。

  

  Mix IDE。

  

  ETH钱包。

  

  注意:关于solc和编译Solidity合约代码的更多信息可在此查看。

  

  在geth设置solidity编译器

  

  如果你启动了geth节点,就可以查看哪个编译器可用。

  

  这一指令会返回到显示当前哪个编译器可用的字符串。

  

  注意:solc编译器和cpp-ethereum一起安装。或者,你可以自己创建。

  

  如果你的solc可执行文件不在标准位置,可以用—solc标志为solc可执行文件指定一个定制路线

  

  或者你可以通过控制台在执行期间设置这个选项:

  

  编译一个简单合约

  

  让我们编译一个简单的合约源:

  

  这个合约提供了一个单一方法multiply,它和一个正整数a调用并返回到a*7。

  

  注意:编译器通过RPC因此也能通过web3.js,对浏览器内任何通过RPC/IPC连接到geth的Ðapp可用。

  

  下面的例子会向你展示如何通过JSON-RPC接合geth来使用编译器。

  

  Code编译的ETH虚拟机字节代码

  

  Info从编译器输出的额外元数据

  

  Source源代码

  

  Language合约语言(Solidity,Serpent,LLL

  

  LanguageVersion合约语言版本

  

  compilerVersion用于编译这个合约的solidity编译器版本。

  

  abiDefinition应用的二进制界面定义

  

  userDoc用户的NatSpec Doc。

  

  developerDoc**者的NatSpec Doc。

  

  编译器输出的直接结构化(到code和info)反映了两种非常不同的部署路径。编译的ETH虚拟机代码和一个合约创建交易被发送到区块,剩下的(info)在理想状态下会存活在去中心化云上,公开验证的元数据则执行***上的代码。

  

  如果你的源包含多个合约,输出会包括每个合约一个入口,对应的合约信息对象可以用作为属性名称的合约名字检索到。你可以通过检测当前的GlobalRegistrar代码来试一下:

  

  创建和部署合约

  

  注意:用在线Solidity实时编译器或Mix IDE程序会更容易完成。

  

  所有的二进制数据都以十六进制的格式序列化。十六进制字符串总会有一个十六进制前缀0x。

  

  注意:注意arg1,arg2,…是合约构造函数参数,以备它要接受参数。如果合约不需要构造函数参数,就可以忽略这些参数。

  

  值得指出的是,这一步骤需要你支付执行。一旦交易成功进入到区块,你的账户余额(你作为发送方放在from领域)会根据ETH虚拟机的gas规则被扣减。一段时间以后,你的交易会在一个区块中出现,确认它带来的状态是共识。你的合约现在存在于***上。以不同步的方式做同样的事看起来是这样:

  

  与合约交互

  

  与合约交互典型的做法是用诸如eth.contract()功能的抽象层,它会返回到javascript对象,和所有可用的合约功能一起,作为可调用的javascript功能。描述合约可用功能的标准方式是ABI定义。这个对象是一个字符串,它描述了调用签名和每个可用合约功能的返回值。

  

  现在ABI中具体说明的所有功能调用都在合约实例中可用。你可以用两种方法中的一种来调用这些合约实例上的方法。

  

  当用sendTransaction被调用的时候,功能调用通过发送交易来执行。需要花费以太币来发送,调用会一直记录在***上。用这种方式进行的调用返回值是交易散表。

  

  当用call被调用的时候,功能在ETH虚拟机被本地执行,功能返回值和功能一起返回。用这种方式进行的调用不会记录在***上,因此也不会改变合约内部状态。这种调用方式被称为恒定功能调用。以这种方式进行的调用不花费以太币。

  

  随着公链等基础设施的完善,未来将会出现更多基于不同应用场景的DAPP,包括:存储、社交、即时通信等领域均已出现相应的代表案例。手机钱包作为***世界的“支付宝”,可以连接DAPP提供的服务端,以及终端用户,因此内嵌DAPP浏览器成为很自然的选择。

  

  当然,如果未来出现杀手级的DAPP,演变成新的流量入口,那么该应用也可能内置钱包和DAPP浏览器的功能,从而和钱包应用争夺入口级的机会。因此,DAPP浏览器在未来更可能内嵌在高频刚需的流量入口中。


相关新闻
联系方式
公司:广州杰肯狸网络科技有限公司
姓名:何经理(先生)
手机:19927739756
地区:广东-广州
地址:广州市天河区珠村西横路5号1栋101-312
微信:btcguge62
拨打电话
微信咨询
请卖家联系我