資源の読み込みに... 荷物...

サポートコード

機能についてexchange.IO概要をまとめていますencode函数呼び出しのエンコーディングをhex文字列形式 公開されているプラットフォームを参照してください.Uniswap V3 トレーディングクラスライブラリ テンプレート特定の用途のために 暗号化の呼び出しunwrapWETH9この方法が例として用いられる.

function main() {
    // Main network address of ContractV3SwapRouterV2: 0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45
    // To call the unwrapWETH9 method, you need to register the ABI first, omit the registration here.
    // "owner" represents the wallet address, it needs to fill in the specific, 1 represents the number of unwrapping, unwrap a WETH into ETH
    var data = exchange.IO("encode", "0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45", "unwrapWETH9(uint256,address)", 1, "owner")
    Log(data)
}

呼び出すときexchange.IO("encode",...)2番目のパラメータ (文字列型) が0x暗号化された方法の呼び出し (encode) スマート契約 始めないなら0x指定されたタイプ順序をコードするために使用されます.abi.encodeについてsolidity次の例を参照してください.

function main() {
    var x = 10 
    var address = "0x02a5fBb259d20A3Ad2Fdf9CCADeF86F6C1c1Ccc9"
    var str = "Hello World"
    var array = [1, 2, 3]
    var ret = exchange.IO("encode", "uint256,address,string,uint256[]", x, address, str, array)   // uint i.e. uint256 , the type length needs to be specified on FMZ
    Log("ret:", ret)
    /*
    000000000000000000000000000000000000000000000000000000000000000a    // x
    00000000000000000000000002a5fbb259d20a3ad2fdf9ccadef86f6c1c1ccc9    // address
    0000000000000000000000000000000000000000000000000000000000000080    // offset of str
    00000000000000000000000000000000000000000000000000000000000000c0    // offset of array
    000000000000000000000000000000000000000000000000000000000000000b    // the length of str
    48656c6c6f20576f726c64000000000000000000000000000000000000000000    // str data
    0000000000000000000000000000000000000000000000000000000000000003    // the length of the array
    0000000000000000000000000000000000000000000000000000000000000001    // array the first data
    0000000000000000000000000000000000000000000000000000000000000002    // array the second data
    0000000000000000000000000000000000000000000000000000000000000003    // array the third data
    */
}

トゥップルまたはトゥップルを含むタイプの順序的なエンコーディングをサポートする:

function main() {
    var types = "tuple(a uint256,b uint8,c address),bytes"
    var ret = exchange.IO("encode", types, {
        a: 30,
        b: 20,
        c: "0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2"
    }, "0011")
    Log("encode: ", ret)
}

このタイプオーダーはtupleそしてbytes呼び出すときに2つのパラメータを入力する必要があります.exchange.IOencode:

  • タイプタプルに対応する変数:
    {
        a: 30,
        b: 20,
        c: "0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2"
    }
    
    送信されたパラメータは,また,構造とタイプのtuple定義されているようにtypesパラメータ:tuple(a uint256, b uint8, c address).
  • タイプバイトに対応する変数:
    "0011"
    

配列や配列を含むタイプの配列コードをサポートする:

function main() {
    var path = ["0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2", "0xdac17f958d2ee523a2206206994597c13d831ec7"]   // ETH address, USDT address
    var ret = exchange.IO("encode", "address[]", path)
    Log("encode: ", ret)
}
Ethereum RPC を呼び出す方法 EncodePacked のサポート