我试图向一个Express应用程序发送二进制数据。只要我的值小于0x80,它就可以正常工作。如果单个值为0x80或更大,则会破坏整个缓冲区。
Express处理程序:
binary = require('binary');
exports.api = function(req, res){
var body = req.body.name;
var buf = new Buffer(body,'binary');
console.log('body',req.body);
console.log('req body len', body.length);
console.log('buf len', buf.length);
var g = binary.parse(buf)
.word16bu('a') // unsigned 16-bit big-endian value
.word16bu('b').vars
console.log('g.a', g.a);
console.log('g.b', g.b);
res.send("respond with a resource");
};
Python客户端(Content-Type: application/x-www-form-urlencoded):
import requests
from struct import pack
# send two unsigned shorts (16-bits each).
requests.post('http://localhost:3000/api', data={'name':pack('!HH',1,2)})
当数据等于1、2时,Express输出。这正是我所期望的。
body { name: '\u0000\u0001\u0000\u0002' }
req body len 4
buf len 4
g.a 1
g.b 2
POST /api 200 1ms - 23b
当数据等于1、0xFF时,输出Express。有趣的是,9520实际上是十六进制中的0x25 0x30,对应于ASCII中的“%0”。是的,它似乎正在解析“%00%01……”字符串。我希望我知道如何防止这种情况!!!
body { name: '%00%01%00%FF' }
req body len 12
buf len 12
g.a 9520
g.b 12325
POST /api 200 2ms - 23b