一,在PHP 内部,系统维护着连接状态,其状态有三种可能的情况:
1,返回0- NORMAL(正常)
2,返回1 - ABORTED(异常退出)
3,返回2 - TIMEOUT(超时)
当 PHP 脚本正常地运行 NORMAL 状态时,连接为有效。当远程客户端中断连接时,ABORTED 状态的标记将会被打开。远程客户端连接的中断通常是由用户点击 STOP 按钮导致的。当连接时间超过 PHP 的时限时,TIMEOUT 状态的标记将被打开。
可以决定脚本是否需要在客户端中断连接时退出。有时候让脚本完整地运行会带来很多方便,即使没有远程浏览器接受脚本的输出。默认的情况是当远程客户端连接中断时脚本将会退出。该处理过程可由 php.ini
的 ignore_user_abort 或由 ignore_user_abort() 函数来控制。如果没有告诉 PHP 忽略用户的中断,脚本将会被中断,除非通过 register_shutdown_function() 设置了关闭触发函数。通过该关闭触发函数,当远程用户点击 STOP 按钮后,脚本再次尝试输出数据时,PHP 将会检测到连接已被中断,并调用关闭触发函数。
脚本也有可能被内置的脚本计时器中断。默认的超时限制为 30 秒。这个值可以通过设置 php.ini
的max_execution_time
。当计数器超时的时候,脚本将会类似于以上连接中断的情况退出,先前被注册过的关闭触发函数也将在这时被执行。在该关闭触发函数中,可以通过调用 connection_status() 函数来检查超时是否导致关闭触发函数被调用。如果超时导致了关闭触发函数的调用,该函数将返回 2。
需要注意的一点是 ABORTED 和 TIMEOUT 状态可以同时有效。这在告诉 PHP 忽略用户的退出操作时是可能的。PHP 将仍然注意用户已经中断了连接但脚本仍然在运行的情况。如果到了运行的时间限制,脚本将被退出,设置过的关闭触发函数也将被执行。在这时会发现函数 connection_status() 返回 3。
二,举例说明
1,ignore_user_abort来监听用户连接状态
<?php ignore_user_abort(false); //不忽视用户中断 sleep(5); //等待5秒 var_dump(connection_status()); //显示用户的连接状态 echo "test"; ob_flush(); //存在输出缓存中的内容取出来,设置为等待输出状态 flush(); //将等待输出缓存中内容,传给用户 //记录时间,以查看是否已经运行 $aaa = fopen("test.txt","a+"); fwrite($aaa, date("Y-m-d H:i:s")." "); fclose($aaa); ?>
2,connection_aborted来判断用户是否中断
<?php error_reporting(E_ALL); //显示报错信息 var_dump(connection_status()); //显示用户的连接状态 sleep(10); //等待10秒 if(connection_aborted()) die; //如果用户连接中断,停止运行 echo "test"; ob_flush(); //存在输出缓存中的内容取出来,设置为等待输出状态 flush(); //将等待输出缓存中内容,传给用户 //记录时间,以查看是否已经运行 $aaa = fopen("test.txt","a+"); fwrite($aaa, date("Y-m-d H:i:s")." "); fclose($aaa); ?>
上面二个例子,都可以测试用户的连接状态,当我们向这个页面发送请求时,在等待的时候,在浏览器上点击停止按钮,或者直接将浏览器关闭掉后,在查看一下test.txt中的时间变化。当然用户中断操作时,就停止程序,可以节约很多系统性能,我想这也是默认的原因。
原文来自: