如何在客户端编写 JavaScript 来及时接收和解析“分块”响应?
我正在使用播放框架来生成分块响应。代码是:
class Test extends Controller {
public static void chunk() throws InterruptedException {
for (int i = 0; i < 10; i++) {
String data = repeat("" + i, 1000);
response.writeChunk(data);
Thread.sleep(1000);
}
}
}
当我使用浏览器访问http://localhost:9000/test/chunk
时,我可以看到显示的数据每秒都在增加。但是,当我编写一个javascript函数来接收和处理数据时,发现它会阻塞,直到收到所有数据。
代码是:
$(function(){
$.ajax(
"/test/chunked",
{
"success": function(data, textStatus, xhr) {
alert(textStatus);
}
}
);
});
10秒后,当所有数据收到时,我可以看到弹出一个消息框。
如何及时获取流并处理数据?
I'm using play framework, to generate chunked response. The code is:
class Test extends Controller {
public static void chunk() throws InterruptedException {
for (int i = 0; i < 10; i++) {
String data = repeat("" + i, 1000);
response.writeChunk(data);
Thread.sleep(1000);
}
}
}
When I use browser to visit http://localhost:9000/test/chunk
, I can see the data displayed increased every second. But, when I write a javascript function to receive and handle the data, found it will block until all data received.
The code is:
$(function(){
$.ajax(
"/test/chunked",
{
"success": function(data, textStatus, xhr) {
alert(textStatus);
}
}
);
});
I can see a message box popped up after 10s, when all the data received.
How to get the stream and handle the data in time?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
很快我们就应该能够使用
ReadableStream
API ( MDN 文档位于此处)。下面的代码似乎适用于 Chrome 版本 62.0.3202.94:Soon we should be able to use
ReadableStream
API (MDN docs here). The code below seems to be working with Chrome Version 62.0.3202.94:当完整的数据传输完成并且连接以 200 响应代码关闭时,将触发
success
事件。我相信您应该能够实现本机onreadystatechanged
事件并查看数据包的到来。the
success
event would fire when the complete data transmission is done and the connection closed with a 200 response code. I believe you should be able to implement a nativeonreadystatechanged
event and see the data packets as they come.jQuery 不支持这一点,但您可以使用普通的 XHR 来做到这一点:
这适用于所有现代浏览器 ,包括 IE 10。W3C 规范此处。
这里的缺点是 xhr.responseText 包含累积的响应。您可以在其上使用子字符串,但更好的主意是使用 responseType 属性并在
ArrayBuffer
上使用slice
。jQuery doesn't support that, but you can do that with plain XHR:
This works in all modern browsers, including IE 10. W3C specification here.
The downside here is that
xhr.responseText
contains an accumulated response. You can use substring on it, but a better idea is to use the responseType attribute and useslice
on anArrayBuffer
.