Quando testar, depurar o código da política, quando executar um robô em disco real, muitas vezes há situações em que se encontram relatórios de erros na interface do exchange, quando se consulta a documentação do API da interface do exchange, para obter informações de erros relevantes, quando se consulta o serviço técnico do API do exchange, sempre é necessário fornecer um relatório de pedido de erro para analisar a causa do erro.
O que é que se passa quando não se vê um jornal e não há como procurar soluções, neste artigo vamos discutir duas soluções.
Primeiro, instalarscapy
Módulo
pip3 install scapy
E então, criar uma estratégia de Python:
from scapy.all import *
def Method_print(packet):
ret = "\n".join(packet.sprintf("{Raw:%Raw.load%}").split(r"\r\n"))
Log(ret)
sniff(
iface='eth0',
prn=Method_print,
lfilter=lambda p: "GET" in str(p) or "POST" in str(p),
filter="tcp")
Em seguida, criar um robô que usa essa política, que irá pegar o pacote http enviado pelo servidor do host (https não consegue pegar e tem algum tratamento para isso).
A partir daí, o bot pode enviar um pedido usando a ferramenta de depuração, e o robô faz o depuração.
function main(){
// 要把基地址设置为其它http协议的地址,如果不设置交易所的地址一般都是https,这样是抓不到包的
exchange.SetBase("http://www.baidu.com")
// POST 请求
exchange.IO("api", "POST", "/api/swap/v3/order", "aaa=111&bbb=222")
// GET 请求
exchange.SetContractType("swap")
exchange.GetTicker()
}
A mensagem foi impressa por um robô:
O blogueiro, que é um dos fundadores do blog, escreveu: O GET solicitou a reportagem:
GET
/api/swap/v3/instruments/BTC-USD-SWAP/ticker
HTTP/1.1
Host: www.baidu.com
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_3) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/35.0.1916.153 Safari/537.36 Accept-Encoding: gzip
可以看到请求报文中的链接为:```/api/swap/v3/instruments/BTC-USD-SWAP/ticker```,是要请求BTC本位的永续合约行情数据。
POST请求报文:
POST /api/swap/v3/ordem HTTP/1.1 Anfitrião: www.baidu.com Agente de usuário: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_3) AppleWebKit/537.36 (KHTML, como Gecko) Chrome/35.0.1916.153 Safari/537.36 Duração do conteúdo: 25 Tipo de conteúdo: aplicação/json; conjunto de caracteres=UTF-8 Ok-Access-Key: d487230f-ccccc-aaaaa-bbbbb-268fef99cfe4 Ok-Access-Passphrase: abc123 O que é que eu quero dizer? Ok-Access-Timestamp: 2020-09-23T08:43:49.906Z Aceitar-Encodificação: gzip
Não, não, não, não.
可以看到请求路径为:```/api/swap/v3/order```。
验证的Access key : ```d487230f-ccccc-aaaaa-bbbbb-268fef99cfe4``` (演示用,并非真KEY)
本次请求的签名:```h1x6f80rhhkELobJcO1rFyMgUUshOlmgjRBHD+pLvG0=```
API KEY 秘钥Passphrase:```abc123``` (演示用)
请求的Body数据:```{"aaa":"111","bbb":"222"}```。
这样就可以观察请求报文了,分析接口请求遇到报错的原因。
### 2、本地监听请求
第二种方法,不需要创建机器人,使用苹果电脑Mac自带的```Netcat``` : https://baike.baidu.com/item/Netcat/9952751?fr=aladdin 。监听请求,并打印报文。
在终端,使用命令```nc -l 8080```,运行起来Netcat。
如图:
![获取托管者发送http请求报文的解决方案](/upload/asset/16ea458dfeb3d64ea2e9.png)
同样我们在本机部署一个托管者,然后在调试工具中,使用如下代码发送请求。
função main() {
exchange.SetBase ((
// GET 请求
exchange.SetContractType("swap")
exchange.GetTicker()
} “`
A mensagem de solicitação de POST impressa no terminal:
O texto do pedido de GET impresso no terminal: