前言
这是一个“人之常情”的实际使用场景。
有时候我们请求一个 php 页面,但是这个页面执行的任务的确没个三五分钟跑不出来,这怎么办?
我们可以让这个任务一直在跑,即使用户关掉了页面。
进一步,我们可以让任务一直跑,但是先向用户返回一个正常的 http 响应。
下面我们来写这两个例子:
让任务驻留,用户关闭窗口继续运行
ignore_user_abort(true); // 后台运行
set_time_limit(0); // 取消脚本运行时间的超时上限
让任务驻留,并且向客户端返回响应
ob_end_clean(); // 清除之前的缓冲内容,这是必需的,如果之前的 buffer 不为空的话,里面可能有http头或者其它内容,导致后面的内容不能及时的输出
header("Connection: close"); // 告诉浏览器,连接关闭了,这样浏览器就不用等待服务器的响应
header("HTTP/1.1 200 OK"); //可以发送200状态码,以这些请求是成功的,要不然可能浏览器会重试,特别是有代理的情况下
ob_start();#开始当前代码缓冲
echo "running,,,,.";
// 下面输出http的一些头信息
$size=ob_get_length();
header("Content-Length: $size");
ob_end_flush(); // 输出当前缓冲
flush(); // 输出PHP缓冲
// 休眠PHP,也就是当前PHP代码的执行停止,1秒钟后PHP被唤醒,
// PHP唤醒后,