- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在将 protobuf 消息加密添加到 this示例。
为此我有:
聊天原型(prototype)
package Chat;
message Message{
required string user = 1;
optional string message = 2;
optional string id = 3;
}
聊天 Controller .js:
...
var builder = ProtoBuf.loadProtoFile(require('path').resolve(sails.config.appPath, "assets/proto/Chat.proto")),
Message = builder.build("Chat").Message;
var encodeMessage = function (message) {
"use strict";
sails.log.info("WILL ENCODE", message);
var msg = new Message(message);
sails.log.info("ENCODED", msg);
return msg;
};
module.exports = {
addConv: function (req, res) {
var data_from_client = req.params.all();
if (req.isSocket && req.method === 'POST') {
// This is the new message
Chat.create(data_from_client).exec(function (err, data_from_client){
Chat.publishCreate({ id: (data_from_client.id),
// I encode only on sending from server
data : encodeMessage({
message: data_from_client.message,
user: data_from_client.user }).toBuffer()
});
});
}
else if (req.isSocket) {
Chat.watch(req.socket);
sails.log.info('USER SUBSCRIBED TO ' + req.socket.id);
}
}
};
和前端的 socketApp.js:
...
ProtoBuf.loadProtoFile("/proto/Chat.proto", function (err, builder) {
Chat = builder.build("Chat"),
Message = Chat.Message;
});
socketApp.controller('ChatController', ['$http', '$log', '$scope', function ($http, $log, $scope) {
var decodeMessage = function (message) {
console.log("WILL DECODE", message);
var msg = Message.decode(message); //Line 23 !Here goes the error!
console.log("DECODED", msg);
return msg;
};
...
io.socket.on('chat', function (obj, keys) {
console.log('chat', obj, keys); //Says that object is: {id: 41, data: ArrayBuffer}
if (obj.verb === 'created') {
console.log(decodeMessage(obj.data));
$scope.chatList.push(decodeMessage(obj.data));
$scope.$digest();
}
});
$scope.sendMsg = function () {
...
};
}]);
每次客户端从服务器获取编码消息时我都会遇到错误:
Uncaught TypeError: Illegal bufferByteBuffer.wrap @ ByteBufferAB.js:390
ProtoBuf.Reflect.MessagePrototype.build.Message.decode @ ProtoBuf.js:2904
decodeMessage @ socketApp.js:23
(anonymous function) @ socketApp.js:56
u.8.Emitter.emit @ sails.io.js:3
u.5.Socket.onevent @ sails.io.js:3
u.5.Socket.onpacket @ sails.io.js:3
u.7.module.exports @ sails.io.js:3
u.8.Emitter.emit @ sails.io.js:3
u.3.Manager.ondecoded @ sails.io.js:3
u.7.module.exports @ sails.io.js:3
u.8.Emitter.emit @ sails.io.js:3
u.43.Decoder.add @ sails.io.js:5
u.3.Manager.ondata @ sails.io.js:3
u.7.module.exports @ sails.io.js:3
u.8.Emitter.emit @ sails.io.js:3
u.12.Socket.onPacket @ sails.io.js:3
(anonymous function) @ sails.io.js:3
u.8.Emitter.emit @ sails.io.js:3
u.13.Transport.onPacket @ sails.io.js:3
u.13.Transport.onData @ sails.io.js:3
u.18.WS.addEventListeners.ws.onmessage @ sails.io.js:4
怎么了?我怎样才能使它工作?
最佳答案
sails-hook-sockets通过套接字接收数据并将其提供给其他中间件使用 lodash 的 _.extend
:参见 here : body : _.extend({}, options.incomingSailsIOMsg.params || {}, options.incomingSailsIOMsg.data || {}),
,我希望在其他几个地方。以某种方式扩展刹车 ArrayBuffer。
所以我发现的唯一方法是在 sails-hook-sockets 处理之前反序列化消息。所以我可以在服务的某个地方写:
ProtoDeserializationService:
ProtoBuf.loadProtoFile("/proto/Chat.proto", function (err, builder) {
Chat = builder.build("Chat"), Message = Chat.Message;;
sails.io.on('connect', function (socket) {
var _onevent = socket.onevent;
sails.log.silly("socket_protobuf: Overriding socket.io onevent method to support deserialization of incoming message");
/**
* Overriden socket.io onevent metod that receives packages
*
* If `packet.data.data` field contains fields `protobuf` and `model` then it should be deserialized according to Protocol Buffers message scheme with name stored in `model`.
*
* @param {Object} packet received data
*/
socket.onevent = function (packet) {
sails.log.silly("socket_protobuf: onevent");
var args = packet.data || [],
data = args[1].data || args[1],
protobuf = data.protobuf || null,
model = data.model|| null;
if (protobuf && model) {
_.extend(data, Message.decode(protobuf));
delete data.protobuf;
delete data.model;
}
_onevent.call(this, packet);
};
});
但我写了更通用的解决方案:hook能够在普通 socket.io 请求和 sails.socket.io Pub/Sub 上序列化 Protocol Buffer 消息.
关于javascript - Sails.js socket.io protobuf.js 编码消息导致错误 : "Illegal buffer" on decode in browser,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33039819/
我试图了解是否有可能采用构成另一个 protobuf 一部分的序列化 protobuf 并将它们合并在一起而不必反序列化第一个 protobuf。 例如,给定一个 protobuf 包装器: synt
正如我最近发现的,我们可以使用两个类 ProtoBuf.Serializer 和 ProtoBuf.Meta.TypeModel 在 protobuf-net 中序列化/反序列化。例如,假设我们有一个
我正在尝试使用 protobuf 序列化我的下面的类,但它因“对象引用”错误而失败。更多详情如下。通过查看错误详细信息,您知道会出现什么问题吗?注意:我的用户对象太大了,它有太多的子对象和属性。所以不
我想识别要反序列化的文件是否是protobuf序列化的。这是因为我想提供不止一种选项来为用户序列化和反序列化文件。我正在使用 protobuf.net 序列化为 protobuf 格式。 最佳答案 不
我已经使用位于 https://protogen.marcgravell.com/ 的工具构建了我的 C# 类来自 https://developers.google.com/transit/gtfs
有一个通过 UDP 接受消息的 Go 服务器。使用这种设计,它只能扫描一种特定类型的实体,world.Entity . for { buf := make([]byte, 10
比如我想序列化和反序列化System.Drawing.Font这是不可变的,不能更改以适应 protobuf-net 约定。一般来说,是否可以在 protobuf-net 中编写某种“自定义”序列化程
我开始用 protobuf 2.2.0 构建一个应用程序,因为它是最新的。现在我正在考虑升级到最新的 protobuf 2.4.0a。 如果我这样做,对于同一架构,一个版本的应用程序生成的消息是否仍然
在我从 BinaryFormatter 切换到 protobuf-net 的过程中, 我在序列化集合时观察到了差异。 在下面的代码示例中,反序列化(protobuf-net v2r470)返回 如果在
知道正在发送的 protobuf 消息类型的 API 是什么? 例如,我使用以下方法获取 SendNameMessage 对象。 SendNameMessage sendNameObj = Seria
我在我们的一个项目中使用 protobuf-net 来序列化/反序列化一大组同类对象。它运行良好,速度非常快。不过只有一个问题。反序列化时是否可以使用 linq(或任何其他机制)指定过滤条件,以便加载
我正在尝试使用 protobuf-net 序列化一些对象,但不幸的是他们自由地使用了 DateTimeOffset , protobuf-net 尚不支持。这导致了很多: No serializer
我在 ionic2 项目中使用 protobuf.js。我有一个有效的 .proto 文件,我首先将其转换为静态 javascript 文件: pbjs -t static databaseapi.p
我通过 vcpkg vcpkg install protobuf:x64-windows 安装了 protobuf .显然它安装了最新版本(3.6.1)。对于我需要版本<=3.5.1的项目。有没有办法
我有以下类(class):- [Serializable] [DataContract(Name = "StateValueWrapper")] public class StateValueWrap
protobuf net 似乎不支持列表/数组的 AsReference 以及列表/数组内对象的 AsReference。这会在最终的 v2 中得到支持吗? [ProtoMember(1, AsRef
我正在使用 protobuf-net 来序列化和反序列化我的消息。我的消息还包含可以为空的字符串。但是,当我在另一侧反序列化它们时,我得到空字符串 ("")。 根据谷歌文档,空字符串中字符串类型的默认
我已经阅读了有关继承的各种帖子,并且 Protocol Buffer 不支持继承。我不想继承 Protocol Buffers 消息,而是继承,这样我就可以轻松处理我的所有 Protocol Buff
我知道带有 protobuf.net 的列表不支持 AsReference,因此我尝试了解决此限制的方法。我创建了一个名为 SuperList 的自定义列表,其中包含包装在 SuperListItem
我正在尝试使用 ProtoMember 中的 AsReference 选项进行递归引用。如果我使用公共(public)构造函数创建 AnOwner 然后序列化/反序列化,AnOwner.Data 变为
我是一名优秀的程序员,十分优秀!