> 백엔드 개발 > PHP 튜토리얼 > javascript - Ajax实现的长轮询如何才能不阻塞同一时间内页面的其他Ajax请求(同域请求)呢?

javascript - Ajax实现的长轮询如何才能不阻塞同一时间内页面的其他Ajax请求(同域请求)呢?

WBOY
풀어 주다: 2016-06-06 20:41:55
원래의
981명이 탐색했습니다.

长轮询的实现是用xmlhttprequest递归得到的,页面一旦加入了这种轮询方式,其他地方的ajax请求就没反应了,比如滚动到页底自动加载新文章。查了资料,据说HTTP 1.1是不允许同一时间客户端向同一服务器建立2个http连接。如何解决?

回复内容:

长轮询的实现是用xmlhttprequest递归得到的,页面一旦加入了这种轮询方式,其他地方的ajax请求就没反应了,比如滚动到页底自动加载新文章。查了资料,据说HTTP 1.1是不允许同一时间客户端向同一服务器建立2个http连接。如何解决?

据说HTTP 1.1是不允许同一时间客户端向同一服务器建立2个http连接

这个说法不对

实际上是不能并发访问同一个站点使用了session的页面,因为访问A页面时,session被锁住了,B页面要等A页面结束释放锁才能被执行。解决方法就是不用session,或者session使用后立刻释放(php 使用session_write_close释放session锁)

回过一次了,再回一次

直接终止轮询返回当前结果(轮询结果,可能为空),发起其他地方的ajax请求,得到结果,然后再开个轮询呗(可能我这想法太naive了),或者改需求哈哈。

其实用轮询的方式实现server push(一般都是这个作用吧?),不如用socket,不过好像其标准还不是太清晰。具体请google,对了昨天还看到个有人分享的文章:消息推送机制技术设计

递归一个LongPolling,在开启第二个请求时,第一个请求的连接已经被关闭了。那实际上就还有一个可用的通道。只要保证后端对应的数据服务返回足够快,那么一个信道也可以不block。

至于别的方案么,绕个圈子JSONP,Flash XML Socket/Websocket,某些Ajax放在别的域下,然后配置server的CORS,或者iframe什么的。

讲一下ifame的数据提交方式

用iframe实际上是用form提交数据的方式,把数据提交给一个iframe,然后返回一个页面在iframe中,页面中是一段js代码
例如

<code><script type="text/javascript">

    window.parent.method(data);

</script>
</code>
로그인 후 복사

用这种方式把数据提交到后台进行处理,在低版本浏览器中,通常使用此方法,上传图片

在当前页面中,要在window对象下定义一个全局对象或方式,可以使用window.parent来调用此方法

使用iframe来提交数据,要与后端进行约定,在前端所执行的js方法。 一般数据提交不建议使用iframe方式。还是ajax较为方使

能不能把长轮询改下请求方式,在客户端使用js定时去请求服务器端,服务器端设置响应的时间。到了设置的时间就去响应。仿照队列,前后端都排好队。先来的先服务。

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿