当前位置: 首页 > news >正文

响应式的网站建设一个多少钱wordpress采集别人公众号

响应式的网站建设一个多少钱,wordpress采集别人公众号,网页设计制作与网站建设课程,公司注册费用流程# 概述 智能合约是部署在区块链上的一串代代码,通常我们与智能合约的打交道 可以通过前端的Dapp,etherscan,metamask 等方式。作为开发人员可以通过调用提供的相关包来与之交互,如web3.js,ether.js , web3.j(java 语言…

# 概述
智能合约是部署在区块链上的一串代代码,通常我们与智能合约的打交道 可以通过前端的Dapp,etherscan,metamask 等方式。作为开发人员可以通过调用提供的相关包来与之交互,如web3.js,ether.js , web3.j(java 语言的包)。那么能否绕过这些东西直接与链发生交互呢?当然可以!
首先来了解第一个概念,区块链节点
任何一台计算机(能联网,且配置够),都可以启动以太坊的客户端来加入区块链,加入后这个节点会同步整个链上的状态,即通过这个节点就可以获取整个链的状态以及通过这个节点可以改变的状态。
第二个,智能合约。简而言之,智能合约是在节点上部署的代码,用户调用时会在节点上执行。
第三个,jsonrpc。jsonrpc 是一个远程调用的协议规范,规定了交互时的入参和出参的格式要求。[jsonrpc中文文档](https://wiki.geekdream.com/Specification/json-rpc_2.0.html)

后面以这个,合约代码为示例演示交互
```javascript
// SPDX-License-Identifier: MIT
pragma solidity =0.8.4;

contract Test {
    uint256 private value;


    function setValue(uint256 _value) public {
        value = _value;
    }

    function getValue() public view returns(uint256){
        return value;
    }
    
}

```


### 使用remix 与合约交互

![[Pasted image 20220402114639.png]]

通过 remix 部署后会出现,可以调用的函数名。这种是最基础的用法

但是当页面刷新后,左下角的可调用的函数名就没了,这种情况下就需要使用 At Address这个按钮了
![[Pasted image 20220402120058.png]]


在代码框只需要提供要调用合约方法的接口,再将要调用的合约放入 At Address的框里,点击按钮,就会出现接口中的方法。这种就是不要合约的实现,只知道方法接口和地址就可以调用了。
合约调用的最核心就是两个东西,一个是部署后的合约地址,另外一个就要方法的接口也就是ABI


### 使用ethscan 与智能合约交互
另外一种与合约交互的方式,是通过ethscan。这种的前提是,合约代码已经在ethscan上进行开源过了。
![[Pasted image 20220402135533.png]]

其中 Read Contact 是读方法,不需要消耗gas.
Write Contact 是写方法,调用这些方法会改变链上的状态,会消耗gas.

### 使用web3.js 与合约交互
再有就是通过web3.js 的库进行交互
```javascript
var fs = require('fs');

var Web3 = require('web3');

const infuraKey = fs.readFileSync("../.infuraKey").toString().trim();

var ethRpcUrl = `https://rinkeby.infura.io/v3/`+infuraKey

var web3 = new Web3(ethRpcUrl);

  

abi = [

{

"inputs": [],

"name": "getValue",

"outputs": [

{

"internalType": "uint256",

"name": "",

"type": "uint256"

}

],

"stateMutability": "view",

"type": "function"

},

{

"inputs": [

{

"internalType": "uint256",

"name": "_value",

"type": "uint256"

}

],

"name": "setValue",

"outputs": [],

"stateMutability": "nonpayable",

"type": "function"

}

]

address = "合约地址"

pk = "钱包私钥"

  

main()

    .then(() => process.exit(0))
    
    .catch(error => {
    
    console.error(error);
    
    process.exit(1);

});

  

async function getValue(){

    var contract = new web3.eth.Contract(abi, address);
    
    var value = await contract.methods.getValue().call();
    
    console.log(value);

}

  
  

async function setValue(){

    value = 123
    
    var contract = new web3.eth.Contract(abi, address);
    
    var encodeABI = await contract.methods.setValue(value).encodeABI();
    
    var signResult = await web3.eth.accounts.signTransaction({
    
    gas: 3000000,
    
    to: address,
    
    data: encodeABI
    
    }, pk);
    
    console.log(signResult);
    
    var result = await web3.eth.sendSignedTransaction(signResult.rawTransaction);
    
    console.log(result);
    
      

}

  

async function main(){

    await setValue();
    
    await getValue();

}
```


### 使用http 请求与智能合约交互
[ethreum json rpc API](https://eth.wiki/json-rpc/API)

https://eth.wiki/json-rpc/API
上面这几种方式都是比较常规的,接下展示一种非常规的操作,即通过http请求来交互

```javascript
var fs = require('fs');

const fetch = require('node-fetch')

var Web3 = require('web3');

const ethers = require('ethers');

const infuraKey = fs.readFileSync("../.infuraKey").toString().trim();

var ethRpcUrl = `https://rinkeby.infura.io/v3/`+infuraKey

var web3 = new Web3(ethRpcUrl);

abi = [

{

"inputs": [],

"name": "getValue",

"outputs": [

{

"internalType": "uint256",

"name": "",

"type": "uint256"

}

],

"stateMutability": "view",

"type": "function"

},

{

"inputs": [

{

"internalType": "uint256",

"name": "_value",

"type": "uint256"

}

],

"name": "setValue",

"outputs": [],

"stateMutability": "nonpayable",

"type": "function"

}

]

contractAddress = "合约地址"

pk = "钱包私钥"

userAccount = "私钥对应的账户地址"

main()

.then(() => process.exit(0))

.catch(error => {

console.error(error);

process.exit(1);

});

  

async function main(){

    await setValue();
    
    await getValue();

}

  
  

async function getNonce(account){

    let nonce = await web3.eth.getTransactionCount(account);
    
    console.log('nonce = ', nonce)
    
    return nonce;

}

  

async function getValue(){

    // 对方法进行sha3编码,然后取前四个字节
    
    // var methodSign = await web3.utils.keccak256("getValue()").substr(0, 10);
    
    var methodSign = await web3.utils.keccak256("getValue()").substr(0, 10);
    
      
    
    // console.log(methodSign)
    
    data = methodSign;
    
    // 如果有入参,对入参进行编码
    
    // encodeParams = web3.eth.abi.encodeParameters(['uint256'],[456]);
    
    // 拼接方法名和入参作为jsonrpc的 params中的data字段的数据
    
    // data +=encodeParams.substr(2,encodeParams.length)
    
    console.log(data)
    
    // 构造post 请求的body参数
    
    var input = {"jsonrpc":"2.0","id":3,"method":"eth_call","params":[{"to":contractAddress,"data":data},"latest"]}
    
    // http 可以一次多个请求
    
    var inputs = [input,input]
    
    // 发送post请求
    
    const resp = await fetch(ethRpcUrl, {
    
        method: "POST",
        
        body: JSON.stringify(inputs),
        
        headers: {
        
        "Content-Type": "application/json"
    
    }
    
    });
    
    var rpcResult = await resp.json();
    
    console.log(rpcResult[0].result)
    
    // 用 ethers包中的方法解析返回结果
    
    var ethersResult = await ethers.utils.defaultAbiCoder.decode(['uint256'], rpcResult[0].result)
    
    // 用 web3包中的方法解析防护结果
    
    var decodeResult = await web3.eth.abi.decodeParameters(['uint256'], rpcResult[0].result);
    
    console.log("vaule is "+ethersResult)
    
    console.log("value is "+decodeResult[0])

  

}

  

async function setValue(){

    // 这里借用web3的方法对要发送的内容进行签名
    var contract = new web3.eth.Contract(abi, contractAddress);
    
    value = 456;
    
    var encodeABI = contract.methods.setValue(value).encodeABI();
    
    var signResult = await web3.eth.accounts.signTransaction({
    
    gas: 3000000,
    
    to: contractAddress,
    
    data: encodeABI,
    
    nonce: await getNonce(userAccount)
    
    }, pk);
    
    console.log(signResult);
    
    rawTransaction = signResult.rawTransaction
    
    // 构造post 请求的body参数
    
    var input = {"jsonrpc":"2.0","id":3,"method":"eth_sendRawTransaction","params":[rawTransaction]}
    
    console.log(input)
    
    var inputs = [input]
    
    // 发送post请求
    
    const resp = await fetch(ethRpcUrl, {
    
        method: "POST",
        
        body: JSON.stringify(inputs),
        
        headers: {
        
        "Content-Type": "application/json"
        
        }
    
    });
    
    var rpcResult = await resp.json();
    
    console.log(rpcResult)

}

```

通过jsonrpc 方式,可以更灵活的与合约进行交互,只要拿到别人的签名信息,只发http请求就可以和链进行交互,至于是谁发送的这个http,就关系不大了。


## 综述
不管是remix 、etherscan 还是web3.js 这几种方式,本质上都是对jsonrpc方法封装。理解它们的底层交互逻辑,可以让我们更深刻的认识这些技术,从而发现它们还是我们日常使用的http请求,也就没有那么神秘了。
 

http://www.yayakq.cn/news/390360/

相关文章:

  • 住房建设部网站 保定设计制作服务方案
  • 司法公开网站建设情况汇报wordpress 百度推送
  • 成都网站建设定制开发系统一个空间放两个php网站
  • 网站推广与优化哪里好杭州拱墅网站建设
  • 吉林网站建设公司跨境电商卖什么产品最赚钱
  • 模板网站自助建站公司网站做的一样算不算侵权6
  • 怎样登入网站后台云空间的网站如何做
  • 金龙网站哪里建设的加网络网站建设工作室
  • 北京网站设计公司youx成都柚米科技15网站建设公司专业网站开发研发
  • 网站正在建设_敬请期待!个人备案网站改企业备案
  • 如何做网站首页优化开发板有什么用
  • 电子商务网站策划ppt特效制作软件
  • 扬州市邗江区建设局网站简述网站建设在作用
  • 云盘做网站网站连接微信支付
  • 服装织梦网站源码正规微商平台
  • 家政服家政服务网站模板电子商务平台搭建方案
  • 网站建设公司推广方式中国大型网站建设公司
  • 如何做一个小程序商城中卫网站推广优化
  • 漳州商城网站建设wordpress速度没织梦快
  • 广州新闻最新消息今天百度关键词优化大师
  • 青海海东平安县建设局网站辽宁建设厅规划设计网站
  • 外贸网站收到询盘wordpress集成微信收款
  • 网站建设 运维 管理做原创视频网站
  • 动易的网站能否静态网站色彩
  • 怎么给我 的网站做关键词芜湖市建设路小学网站
  • 海报设计 网站黑龙江公司网站建设
  • 什么网站做h5好竹山县建设局网站
  • 网站建设备案书模板用red5做直播网站
  • 网页设计作业 个人网站做网站具体步骤
  • 富锦网站网站云优化