您好,欢迎访问一九零五行业门户网

php fscokopen实现数据异步调用代码

php fscokopen实现数据异步调用代码
我们就可以使用fsockopen连接到本地服务器,触发脚本执行,然后立即返回,不等待
脚本执行完成。
function triggerrequest($url,
$post_data
=
array(),
$cookie
=
array())…{
        $method
=
get;  //可以通过post或者get传递一些参数给要触发的脚本
$url_array
=
parse_url($url); //获取url信息,以便平凑http header
$port
=
isset($url_array['port'])?
$url_array['port'] :
80;
$fp
=
fsockopen($url_array['host'],
$port,
$errno,
$errstr,
30);
        if (!$fp) …{
                return
false;
        }
        $getpath
=
$url_array['path'] .?.
$url_array['query'];
        if(!empty($post_data))…{
                $method
=
post;
        }
        $header
=
$method
.
.
$getpath;
        $header
.=
http/1.1rn;
        $header
.=
host: .
$url_array['host'] .
rn
; //http 1.1 host域不能省略
/**//*以下头信息域可以省略
        $header .= user-agent: mozilla/5.0 (windows; u; windows nt 5.1; en
-us; rv:1.8.1.13) gecko/20080311 firefox/2.0.0.13 rn;
        $header .= accept:
text/xml,application/xml,application/xhtml+xml,text/html;q=0.9,text/plain;q=
0.8,image/png,q=0.5 rn;
        $header .= accept-language: en-us,en;q=0.5 ;
        $header .= accept-encoding: gzip,deflatern;
         */
        $header
.=
connection:closern;
        if(!empty($cookie))…{
                $_cookie
=
strval(null);
                foreach($cookie
as
$k
=>
$v)…{
                        $_cookie
.=
$k.=.$v.; ;
                }
                $cookie_str
=
cookie:
.
base64_encode($_cookie) . rn;//传递cookie
$header
.=
$cookie_str;
        }
        if(!empty($post_data))…{
                $_post
=
strval(null);
                foreach($post_data
as
$k
=>
$v)…{
                        $_post
.=
$k.=.$v.&;
                }
                $post_str
=
content-type: application/x-www-form-urlencodedrn;//post数据
$post_str
.=
content-length: .
strlen($_post) . rn;//post数据的长度
$post_str
.=
$_post.rnrn ; //传递post数据
$header
.=
$post_str;
        }
        fwrite($fp,
$header);
        //echo fread($fp, 1024); //我们不关心服务器返回
fclose($fp);
        return
true;
}
现在,就可以通过这个函数来触发一个php脚本的执行,然后函数就会返回。 我们
就可以接着执行下一步操作了。
   还有一个问题就是,当客户端断开连接以后。也就是triggerrequest发送请求后,
立即关闭了连接,那么可能会引起服务器端正在执行的脚本退出。
   在 php 内部,系统维护着连接状态,其状态有三种可能的情况:
    * 0 - normal(正常)
    * 1 - aborted(异常退出)
    * 2 - timeout(超时)
     当 php 脚本正常地运行 normal 状态时,连接为有效。当客户端中断连接时,
aborted状态的标记将会被打开。远程客户端连接的中断通常是由用户点击 stop 按钮
导致的。当连接时间超过 php 的时限(请参阅set_time_limit() 函数)时,timeout
状态的标记将被打开。
    可以决定脚本是否需要在客户端中断连接时退出。有时候让脚本完整地运行会带来
很多方便,即使没有远程浏览器接受脚本的输出。默认的情况是当远程客户端连接中断
时脚本将会退出。该处理过程可由 php.ini 的 ignore_user_abort 或由 apache
.conf设置中对应的“php_value ignore_user_abort”以及 ignore_user_abort() 函
数来控制。如果没有告诉php 忽略用户的中断,脚本将会被中断,除非通过
register_shutdown_function()设置了关闭触发函数。通过该关闭触发函数,当远程用
户点击 stop 按钮后,脚本再次尝试输出数据时,php将会检测到连接已被中断,并调
用关闭触发函数。
     脚本也有可能被内置的脚本计时器中断。默认的超时限制为 30 秒。这个值可以
通过设置 php.ini 的max_execution_time 或 apache .conf 设置中对应的
“php_valuemax_execution_time”参数或者 set_time_limit()函数来更改。当计数器
超时的时候,脚本将会类似于以上连接中断的情况退出,先前被注册过的关闭触发函数
也将在这时被执行。在该关闭触发函数中,可以通过调用 connection_status() 函数
来检查超时是否导致关闭触发函数被调用。如果超时导致了关闭触发函数的调用,该函
数将返回 2。
     需要注意的一点是 aborted 和 timeout 状态可以同时有效。这在告诉 php 忽略
用户的退出操作时是可能的。php将仍然注意用户已经中断了连接但脚本仍然在运行的
情况。如果到了运行的时间限制,脚本将被退出,设置过的关闭触发函数也将被执行。
在这时会发现函数connection_status() 返回 3。
      所以还在要触发的脚本中指明:
ignore_user_abort(true); //如果客户端断开连接,不会引起脚本abort.
set_time_limit(0);//取消脚本执行延时上限
     或者,也可以使用:
register_shutdown_function(callback fuction[, parameters]);//注册脚本退出时
执行的函数
其它类似信息

推荐信息