php怎么样提前响应,后续代码在后台继续运行,但是阻塞模式

<?php
//PHP 中如何 在客户端触发,然后在服务器端执行一个函数,页面关闭也继续执行。要先返回用户请求不要等待时。

 ob_end_clean();#清除之前的缓冲内容,这是必需的,如果之前的缓存不为空的话,里面可能有http头或者其它内容,导致后面的内容不能及时的输出
 header("Connection: close");//告诉浏览器,连接关闭了,这样浏览器就不用等待服务器的响应
 header("HTTP/1.1 200 OK"); //可以发送200状态码,以这些请求是成功的,要不然可能浏览器会重试,特别是有代理的情况下
 //return false;//加了这个下面的就不执行了,不加这个无法返回页面状态,浏览器一直在等待状态,可以关闭,但不是要的效果。
 //die(); 或 return ;也一样不执行下面的
 //rundata();
 //register_shutdown_function("rundata");
 //return  ;
 ob_start();#开始当前代码缓冲
header("Content-type:text/html;charset=utf-8");
  echo "running,,,,.";
echo "您的订单已经被处理,因现在是高峰期,请过几分钟中再查看您的订单状态!";
 //下面输出http的一些头信息
 $size=ob_get_length();
 header("Content-Length: $size");
 ob_end_flush();#输出当前缓冲
 flush();#输出PHP缓冲

 #休眠PHP,也就是当前PHP代码的执行停止,1秒钟后PHP被唤醒,
 #PHP唤醒后,继续执行下面的代码,但这个时候上面代码的结果已经输出浏览器了,
 #也就是浏览器从HTTP头中知道了服务端关闭了连接,浏览器将不在等待服务器的响应,
 #反应给客户的就是页面不会显示处于加载状态中,换句话说用户可以关掉当前页面,或者关掉浏览器,
 #PHP唤醒后继续执行下面的代码,这也就实现了PHP后台执行的效果,
 #休眠的作用只是让php先把前面的输出作完,不要急于马上执行下面的代码,休息一下而已,也就是说下面的代码
 #执行的时候前面的输出应该到达浏览器了
 sleep(1);
 echo '这里的输出用户看不到,后台运行的';

 //下面代码的任何输出都不会输出给浏览器,因为http连接已经关了,
 //所以下面的代码的执行属于后台运行的

 ignore_user_abort(true); // 后台运行,这个只是运行浏览器关闭,并不是直接就中止返回200状态。
 set_time_limit(0); // 取消脚本运行时间的超时上限
 rundata();
$i=0;
     do{
         sleep(60); // 休眠1分钟
         $i++;
         error_log($i.'-',3,'aa.txt');
     }while(true);

function rundata(){//do something
}
?>

猜你喜欢

转载自blog.csdn.net/oZhengTuoJiaSuo/article/details/78479744