为什么浏览器关闭后PHP还会一直执行啊

127.0.0.1/a.php set_time_limit0;
while true { file_put_contents./a, "data ", FILE_APPEND; sleep1;
}

我关闭浏览器后为什么发现a文件还在写啊,我删了a文件还是会继续生成,不是说关闭连接后PHP默认终止脚本吗?

但是前提是你对ignore_user_abort函数是否设置为false,如果为true,那么当用户关闭浏览器后,php页面还会继续执行!同时发现你对页面设置了set_time_limit0,就是说脚本不会超时!只要调整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

<?php
for$i=0;$i<5;$i++ { sleep1;
}
file_put_contents/tmp/info.txt, $i;

测试:
time curl http://127.0.0.1/info.php
Ctrl+C中断请求PHP-FPM最后还是生成了文件info.txt.
因为该请求没有输出,PHP无法检测用户是否已中断连接.

PHP在发送信息给浏览器时,才能检测连接是否已经中断.
比如执行这段代码,在5秒内中断请求,将不会生成文件info.txt:

for$i=0;$i<5;$i++ { echo $i; ob_flush; flush; sleep1;
}
file_put_contents/tmp/info.txt, $i;

发表评论

电子邮件地址不会被公开。 必填项已用*标注