1703878341
1703878342
1703878343
1703878344
Oraclize将在看到上述查询60s之后进行查询。所以,如果第一个实参是数字,就假定我们在预约查询。
1703878345
1703878346
4.自定义gas
1703878347
1703878348
就像其他任何交易一样,从Oraclize到_callback函数的交易要花费gas,即需要向Oraclize支付gas费用。Oraclize_query进行查询收取的以太币还用于在调用_callback函数时提供gas。调用_callback函数时,Oraclize默认提供200000个gas。
1703878349
1703878350
这个返回的gas费用实际上受用户控制,因为用户编写的_callback等方法中的代码可以预估费用。所以当用Oraclize进行查询时,还可以在_callback交易上指定gasLimit应当是多少。但需要注意的是,因为是由Oraclize发送交易,所以没有花费的gas将被返还给Oraclize,而非用户。
1703878351
1703878352
如果200000 gas(默认值,也是最小值)不够,可以指定一个更大的gasLimit,代码如下:
1703878353
1703878354
1703878355
1703878356
1703878357
可以看到,如果最后一个实参是数字,就假定它是自定义的gas。在程序代码中,Oraclize将对回调函数交易使用一个500000的gas上限,而非200000。因为我们让Oraclize提供gas,所以Oraclize在调用oraclize_query时将扣除更多以太币(根据需要多少gas)。
1703878358
1703878359
1703878360
注意:如果给出的gasLimit过小,且_callback方法很长,那么可能永远看不到回调函数。还应注意,自定义的gas一定要大于200000。
1703878361
1703878362
5.回调函数(callback function)
1703878363
1703878364
一旦结果准备好了,Oraclize将把交易发送回合约地址,并调用如下三个方法中的一个:
1703878365
1703878366
·对于每个查询来说,_callback(bytes32 myid,string result)“.”Myid都是一个独特的ID。这个ID由oraclize_query方法返回。如果合约里有多个oraclize_query调用,则将这用于匹配该结果的查询。
1703878367
1703878368
·如果需要TLSNortary的proof,则结果为_callback(bytes32 myid,string result,bytes proof)。
1703878369
1703878370
·如果没有其他方法,回退函数是function()。
1703878371
1703878372
下面是_callback函数的一个例子:
1703878373
1703878374
1703878375
1703878376
1703878377
6.解析助手
1703878378
1703878379
HTTP请求返回的结果可以是HTML、JSON、XML或二进制等格式。在Solidity中,解析结果是很困难的,且代价很高。Oraclize提供了解析助手,在服务端上处理解析,最终得到的结果就是用户需要的那部分。
1703878380
1703878381
为了让Oraclize解析结果,用户需要把URL和下面某一个解析助手(Parsing helpers)“打包”:
1703878382
1703878383
·xml(..)和json(..)助手让Oraclize只返回部分JSON或者用XML解析的返回值,例如:
1703878384
1703878385
·为了得到全部返回值,使用带有api.kraken.com/0/public/Ticker?pair=ETHUSD URL实参的URL数据源。
1703878386
1703878387
·如果只想要最终价字段,需要使用JSON解析调用json(api.kraken.com/0/public/Ticker?pair=ETHUSD).result.XETHZUSD.c.0。
1703878388
1703878389
·html(..).xpath(..)助手用于HTML scraping,仅需指定想用作xpath(..)实参的XPATH,例如:
1703878390
[
上一页 ]
[ :1.703878341e+09 ]
[
下一页 ]