Could not decode a text frame as UTF-8 的解决
2016-03-19 22:51
1411 查看
我准备用谷歌的protobuf作为前后端通信的协议。
但是从服务器发送Message对象到web的时候爆了这个错。很奇怪是什么意思,我明明发的是二进制数据啊,何来的text。。。。
我想起来我在服务器端使用的websocket库是从Github上抄来的,而Github上给出的例子就是发送文本,但是去库的源码里找了一圈没发现有什么地方定义数据格式的啊
又去网上找了一下websocket的一些介绍,发现一张图
websocket的消息是分片发送的,每一片的开头定义了基本的信息。如这张图显示的。第0位0或1表示是不是连续分片的最后一片,123位必须是0,4567四位是一个16进制数字。这个数字是0代表附加数据,1代表文本,2代表二进制数据。
原来就是这4位定义了数据格式。。。
回去看socket库的源码,它在开头写入了一个数字“129”。这个数字转成二进制后“10000001”,果然和网上说的一样。赶紧改成130(10000002),从新试了一下
不报错了,破费!
以前都是直接和c++的后端通讯的,想发什么数据直接发了,在包头写好长度,然后在循环里面去读socket收到的数据。Websocket省事的地方就是格式和长度之类的他都帮你弄好了,收到的直接就是整块的数据,省事也是挺省事的,不过还得折腾一番
但是从服务器发送Message对象到web的时候爆了这个错。很奇怪是什么意思,我明明发的是二进制数据啊,何来的text。。。。
我想起来我在服务器端使用的websocket库是从Github上抄来的,而Github上给出的例子就是发送文本,但是去库的源码里找了一圈没发现有什么地方定义数据格式的啊
又去网上找了一下websocket的一些介绍,发现一张图
websocket的消息是分片发送的,每一片的开头定义了基本的信息。如这张图显示的。第0位0或1表示是不是连续分片的最后一片,123位必须是0,4567四位是一个16进制数字。这个数字是0代表附加数据,1代表文本,2代表二进制数据。
原来就是这4位定义了数据格式。。。
回去看socket库的源码,它在开头写入了一个数字“129”。这个数字转成二进制后“10000001”,果然和网上说的一样。赶紧改成130(10000002),从新试了一下
不报错了,破费!
以前都是直接和c++的后端通讯的,想发什么数据直接发了,在包头写好长度,然后在循环里面去读socket收到的数据。Websocket省事的地方就是格式和长度之类的他都帮你弄好了,收到的直接就是整块的数据,省事也是挺省事的,不过还得折腾一番
相关文章推荐
- 2015-2016网页设计趋势分析 Web Design of Trends
- javascript轻量级库createjs使用Easel实现拖拽效果
- 浅析nodejs实现Websocket的数据接收与发送
- 基于html5和nodejs相结合实现websocket即使通讯
- Android中使用WebSocket实现群聊和消息推送功能(不使用WebView)
- php使用websocket示例详解
- php+html5基于websocket实现聊天室的方法
- Javascript WebSocket使用实例介绍(简明入门教程)
- java中实现兼容ie6 7 8 9的spring4+websocket
- HTML5之WebSocket入门3 -通信模型socket.io
- Spring和Websocket相结合实现消息的推送
- Python实现同时兼容老版和新版Socket协议的一个简单WebSocket服务器
- Python通过websocket与js客户端通信示例分析
- CreateJs系列教程-1-开始出发
- CreateJs系列教程之 EaselJs_2_绘制文字(Text)
- CreateJs系列教程之 EaselJs_3_绘制移动矩形(Shape)
- CreateJs系列教程之 EaselJs_4_绘制图片(Bitmap)
- CreateJs系列教程之 EaselJs&Tween_5_绘制点击提示(Shape,Tween)
- CreateJs系列教程之 EaselJs_6_绘制动画走秀(spriteSheet)