127.0.0.1/a.phpset_time_limit(0);while (true) { file_put_contents('./a', data\r\n, file_append); sleep(1);}
我关闭浏览器后为什么发现a文件还在写啊,我删了a文件还是会继续生成,不是说关闭连接后php默认终止脚本吗?
回复内容: 127.0.0.1/a.phpset_time_limit(0);while (true) { file_put_contents('./a', data\r\n, file_append); sleep(1);}
我关闭浏览器后为什么发现a文件还在写啊,我删了a文件还是会继续生成,不是说关闭连接后php默认终止脚本吗?
但是前提是你对ignore_user_abort()函数是否设置为false,如果为true,那么当用户关闭浏览器后,php页面还会继续执行!同时发现你对页面设置了set_time_limit(0),就是说脚本不会超时!只要调整ignore_user_abort()就好了
浏览器发起请求,然后服务器开始执行,一直执行到服务器脚步运行完毕或者出现异常或者timeout。浏览器没法关闭服务器的运行。
但是……
技术总是不挺发展,rfc http 1.1 定义了 connection 响应头,具体的可以参考 php的连接处理。
http的无状态协议 这个是历史遗留问题,现在的 http 版本也正在解决这个问题,比如上面提到的长链接。定义在 rfc2616(http 1.1)的 connection。
https://segmentfault.com/q/1010000000627...
是使用 nginx + php 还是apache + php ,还是其他 webserver + php
nginx + php,严格的说是 phpfpm + php 的确会出现这个情况
php在发送信息给客户端时,才能检测连接是否已经中断.
http://php.net/manual/zh/function.ignore...
php.ini中ignore_user_abort默认是off,不忽略用户的中断,也就是客户端断开连接后,脚本将被中止.
在php尝试发送信息到客户端之前,不会检测到用户是否已中断连接.
仅使用echo语句不能确保信息已发送,参见flush()函数.
info.php
测试:
time curl http://127.0.0.1/info.php
ctrl+c中断请求(php-fpm)最后还是生成了文件info.txt.
因为该请求没有输出,php无法检测用户是否已中断连接.
php在发送信息给浏览器时,才能检测连接是否已经中断.
比如执行这段代码,在5秒内中断请求,将不会生成文件info.txt:
for($i=0;$i