摘要:但,在这个期间,还有一个动作需要执行,火币服务器会每隔秒,向客户端发送一条数据,客户端接收到这种信息的时候,需要一条对应的数据,内容是的数据体相应的数据格式如下,如果服务器在发送两条数据后没有收到客户端返回的数据,火币服务器就会关闭连接。
火币 websocket 获取 k 线数据,和其它数据 API
</>复制代码
火币官方文档地址: https://huobiapi.github.io/do...
pako(解压gzip): https://github.com/nodeca/pako
参考链接(地址可能已过时,但内容没有): https://www.cnblogs.com/zhumi...
坑死,接火币 websocket 地址 wss://api.huobi.pro/ws 的时候接到怀疑人生,怎么都无法建立连接,一度以为自己没有像其它 get/post 接口那样传入该传的参数,又以为是 wss 走的是 SSL 通道,所以才没能建立连接,还以为是需要服务端转接一下。
但,最后的最后,竟然发现是因为地址的问题,这个地址根本接入不了,至少我这边是接入不进去。
后来换这个地址: wss://api.hadax.com/ws就顺利的接入了
火币 websocket 规则先建立连接
客户端发送订阅请求,这个官方文档有说明
火币服务器返回订阅成功与否的回馈信息
如果成功就定时发送 gzip 压缩后的数据,解压 gzip 你需要 pako https://github.com/nodeca/pako
我们自己客户端这边接收数据,并解压数据,才能获取到真正的 json 数据
自己做前端该做的相应操作,压入数据,展示数据什么的。
但,在这个期间,还有一个动作需要执行,火币服务器会每隔 5 秒,向客户端发送一条 ping 数据,客户端接收到这种信息的时候,需要 send 一条对应的 pong 数据,内容是 ping 的数据体(相应的数据格式如下),如果服务器在发送两条 ping 数据后没有收到 客户端返回的 pong 数据,火币服务器就会关闭连接。
关于其它信息的获取,查看官方文档关于 websocket 的说明就可以了。
</>复制代码
// 服务器发送的 ping 数据
{ ping: 1562741680416 }
// 客户端返回服务器的 pong 数据
{ pong: 1562741680416 }
执行代码
</>复制代码
// K 线相关
let hburl = "wss://api.huobipro.com/ws"; // 实时币种价格
let haurl = "wss://api.hadax.com/ws";
let requestK = { // 请求对应信息的数据
req: "market.bchusdt.kline.1min",
id: "bchusdt",
from: Math.round(new Date().getTime()/1000) - 60,
to: Math.round(new Date().getTime()/1000)
};
let subK = { // 订阅数据
sub: "market.bchusdt.kline.1min",
id: "bchusdt"
};
let socketK = new WebSocket(haurl);
socketK.onopen = function () {
console.log("connection establish");
socketK.send(JSON.stringify(subK));
socketK.send(JSON.stringify(requestK));
};
socketK.onmessage = function (event) {
let blob = event.data;
let reader = new FileReader();
reader.onload = function (e) {
let ploydata = new Uint8Array(e.target.result);
let msg = pako.inflate(ploydata, {to: "string"});
handleData(msg);
};
reader.readAsArrayBuffer(blob, "utf-8");
};
socketK.onclose = function () {
console.log("connection closed");
};
// 处理接收到的信息
function handleData(msg) {
let data = JSON.parse(msg);
if (data.ping) {
// 如果是 ping 消息
sendHeartMessage(data.ping);
} else if (data.status === "ok") {
// 响应数据
handleReponseData(data);
} else {
// 数据体
console.log(data)
}
}
// 发送响应信息
function sendHeartMessage(ping) {
socketK.send(JSON.stringify({"pong": ping}));
}
function handleReponseData(data) {
}
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/105527.html
摘要:作为开发同学的小伙伴客户端的浏览器,有点小调皮还做了一个同源策略的限制,当我们的数据请求遇到不同源的情况下跨域,我们就得尝试其它的通信方法,不能一条道走到黑。 showImg(https://segmentfault.com/img/bVburZO?w=600&h=450); Web2.0以来,Ajax的出世,解决了传统表单提交页面跳转,闪烁白屏等问题。使得Web页面可以实现局部更新,...
摘要:大家明天一起去唱吧关于数据库设计当前一版不会固定大家的数据库设计,大家可以自己自由设计,同时搭上自己的项目,构建一个附带的自项目。 InChat 一个IM通讯框架 一个轻量级、高效率的支持多端(应用与硬件Iot)的异步网络应用通讯框架。(核心底层Netty) Github:InChat 版本目标:完成基本的消息通讯(仅支持文本消息),离线消息存储,历史消息查询,一对一聊天、自我聊天、群...
阅读 3178·2023-04-25 20:43
阅读 1775·2021-09-30 09:54
阅读 1635·2021-09-24 09:47
阅读 2937·2021-09-06 15:02
阅读 3557·2021-02-22 17:09
阅读 1290·2019-08-30 15:53
阅读 1484·2019-08-29 17:04
阅读 2004·2019-08-28 18:22
极致性价比!云服务器续费无忧!
Tesla A100/A800、Tesla V100S等多种GPU云主机特惠2折起,不限台数,续费同价。
NVIDIA RTX 40系,高性价比推理显卡,满足AI应用场景需要。
乌兰察布+上海青浦,满足东推西训AI场景需要