Khi thử nghiệm và gỡ lỗi mã chiến lược, hoặc chạy bot trong một thị trường thực tế, giao diện nền tảng thường được báo cáo với lỗi. Tại thời điểm này, bạn cần truy vấn tài liệu API giao diện nền tảng, tìm kiếm thông tin báo cáo lỗi có liên quan và luôn cần cung cấp các thông báo yêu cầu lỗi, khi truy vấn dịch vụ kỹ thuật API nền tảng, để phân tích nguyên nhân của lỗi.
Trong bài viết này, chúng ta sẽ thảo luận về hai giải pháp.
Đầu tiên, cài đặtscapy
.
pip3 install scapy
Sau đó, tạo ra một chiến lược 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")
Sau đó tạo một bot sử dụng chiến lược, và bot sẽ bắt các gói http được gửi bởi máy chủ docker (https không thể bắt được các gói, và chúng tôi có một số xử lý cho điều đó).
Chạy packet capture bot, và sau đó bạn có thể sử dụng công cụ gỡ lỗi để gửi yêu cầu để cho bot chụp gói. trong công cụ gỡ lỗi, chúng tôi viết mã có thể gửi yêu cầu.
function main(){
// The base address should be set to the address of other http protocols. If the address of a platform is not set, it is generally https, so the packet cannot be captured.
exchange.SetBase("http://www.baidu.com")
// POST request
exchange.IO("api", "POST", "/api/swap/v3/order", "aaa=111&bbb=222")
// GET request
exchange.SetContractType("swap")
exchange.GetTicker()
}
Thông tin được in bởi bot của gói bắt:
Chúng ta có thể sao chép các tin nhắn yêu cầu và xem xét: GET yêu cầu thông báo:
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
You can see the link in the request message is: ```/api/swap/v3/instruments/BTC-USD-SWAP/ticker```, which is to request the crypto-margined (BTC) perpetual contract market data.
POST request message:
POST /api/swap/v3/order HTTP/1.1 Chủ nhà: www.baidu.com User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_3) AppleWebKit/537.36 (KHTML, giống như Gecko) Chrome/35.0.1916.153 Safari/537.36 Nội dung dài: 25 Content-Type: application/json; charset=UTF-8 Ok-Access-Key: d487230f-ccccc-aaaaa-bbbbb-268fef99cfe4 Ok-Access-Passphrase: abc123 OK-Access-Sign: h1x6f80rhhkELobJcO1rFyMgUUshOlmgjRBHD+pLvG0= Ok-Access-Timestamp: 2020-09-23T08:43:49.906Z Chấp nhận mã hóa: gzip
{C:$0000FF}Tạm dịch:
You can see the request path is: ```/api/swap/v3/order```.
Verified Access key: ```d487230f-ccccc-aaaaa-bbbbb-268fef99cfe4``` (for demo, not real KEY)
Signature of this request: ```h1x6f80rhhkELobJcO1rFyMgUUshOlmgjRBHD+pLvG0=```
API KEY Passphrase: ```abc123``` (for demo)
Requested Body data: ```{"aaa":"111","bbb":"222"}```.
Thus, we can observe the request messages, and analyze the causes of errors encountered by the interface.
### 2. Local Listener Request
The second solution, without creating a bot, is to use the ```Netcat``` that comes with the Mac system: https://baike.baidu.com/item/Netcat/9952751?fr=aladdin. Listen to requests and print messages.
In the terminal, use the command ```nc -l 8080``` to run Netcat.
As is shown in the picture:
![Solutions to Obtaining Docker Http Request Message](/upload/asset/16ea458dfeb3d64ea2e9.png)
Similarly, we deploy a docker on this machine, and then in the debugging tool, use the following code to send a request.
chức năng chính
exchange.SetBase ((
// GET request
exchange.SetContractType("swap")
exchange.GetTicker()
} “`
Thông báo yêu cầu POST được in trên thiết bị đầu cuối:
Thông báo yêu cầu GET được in trên thiết bị đầu cuối: