在使用file_get_contents函数的时候,常常会出现超时的状况,在这里要经过查看一下错误提示,看看是哪一种错误,比较常见的是读取超时,这种状况你们能够经过一些方法来尽可能的避免或者解决。这里就简单介绍两种: html
1、增长超时的时间限制 web
这里须要注意:set_time_limit只是设置 你的PHP程序的超时时间,而不是file_get_contents函数读取URL的超时时间。
我一开始觉得set_time_limit也能影响到file_get_contents,后来经测试,是无效的。真正的修改file_get_contents延时能够用resource $context的timeout参数: 算法
2、一次有延时的话那就多试几回 安全
有时候失败是由于网络等因素形成,没有解决办法 ,可是能够修改程序,失败时重试几回,仍然失败就放弃,由于file_get_contents()若是失败将返回 FALSE,因此能够下面这样编写代码: 网络
$cnt=0;
while($cnt < 3 && ($str=@file_get_contents('http...'))===FALSE) $cnt++; 函数
以上方法对付超时已经OK了。 post
这里会出现一个潜在的错误:若是文件不存在的话,程序将进入死循环,所以,加入判断次数。假设只检查4次。
测试
4次以后还没取到,直接进入下一个函数吧!上面只是终止所有操做,这里的函数能够自行配置 ui
那么Post呢?细心点有人发现了'method'=>"GET", 对!是否是能设置成post呢?百度找了下相关资料,还真能够!并且有人写出了山寨版的post传值函数,以下: 加密
function Post($url, $post = null)
{
$context = array();
if (is_array($post))
{
ksort($post);
$context['http'] = array
(
'timeout'=>60,
'method' => 'POST',
'content' => http_build_query($post, '', '&'),
);
}
return file_get_contents($url, false, stream_context_create($context));
}
$data = array
(
'name' => 'test',
'email' => 'test@gmail.com ',
'submit' => 'submit',
);
echo Post('http://www.updateweb.cn', $data);
OK , 上面函数完美了,既解决了超时控制又解决了Post传值。再配合康盛的改良版RC4加密解密算法,作一个安全性很高的webservice就简单多了。