我想通过JavaScript从html页面向我的服务器发送二进制数据,但是服务器接收的字节不一样。接收到的字节似乎被转换为unicode字符串,请参见下面的示例:
xhr.open('POST', '/check', true);
xhr.setRequestHeader('cache-control', 'no-cache');
xhr.setRequestHeader('Content-Type', 'application/octet-stream');
xhr.send('\x41\xFE\x80');服务器应该收到‘A欧元’,但它得到了A├¥┬Ç。
我测试了很多东西,比如:
//xhr.overrideMimeType('text/plain; charset=iso-8859-1');
//xhr.setRequestHeader('Content-type', 'text/plain; charset=iso-8859-1');
//xhr.setRequestHeader('Content-type', 'application/xml; charset=UTF-8');
//xhr.overrideMimeType('text/plain; charset=x-user-defined');
//xhr.overrideMimeType('text\/plain; charset=x-user-defined');在服务器端,我运行plackup (http://localhost:5000/index.html),而$env->{'CONTENT_LENGTH'}是5,所以服务器实际上似乎得到了5字节A├¥┬Ç。
任何关于如何接收原始二进制数据的提示都是很好的。
发布于 2019-02-25 12:32:27
我的Javascript是正确的
事实并非如此。正如我在注释中所暗示的,对于二进制数据,请使用Uint8Array而不是字符串:
xhr.send(new Uint8Array([0x41, 0xFE, 0x80]));如果你已经有了一根绳子..。这应该是可行的:
xhr.send(new Uint8Array(Array.from('\x41\xFE\x80').map(x => x.charCodeAt(0)))解释:send说:
如果
body是Document,那么将请求体设置为body、序列化、转换为Unicode和UTF-8编码。 否则,将请求体和extractedContentType设置为提取body的结果。
String不是Document,因此第一个选项不适用。“提取”的定义在 spec中找到。
USVString: 将
action设置为在object上运行UTF-8编码的操作。 将Content-Type设置为text/plain;charset=UTF-8。 将source设置为object。
您可以看到字符串的UTF-8编码是什么样子的:
new TextEncoder().encode('\x41\xFE\x80')
// => Uint8Array(5) [65, 195, 190, 194, 128]https://stackoverflow.com/questions/54865490
复制相似问题