首先解决file_get_contents的超时问题,在超时返回错误后就象js中的settimeout那样进行一次尝试,错误超过3次或者5次后就确认为无法连线伺服器而彻底放弃。
这里就简单介绍两种解决方法:
一、增加超时的时间限制
注意:set_time_limit只是设定你的PHP程式的超时时间,而不是file_get_contents函数读取URL的超时时间。
我一开始以为set_time_limit也能影响到file_get_contents,后来经测试是无效的。真正的修改file_get_contents延时可以用resource $context的timeout参数:
PHP程式码
$opts = array(
'http'=>array(
'method'=> ;"GET",
'timeout'=>60,
)
);
$context = stream_context_create($opts);
$html =file_get_contents ('http://www.example.com', false, $context);
fpassthru($fp);
二、多次尝试
PHP程式码
$cnt=0;
while($cnt < 3 && ($str=@file_get_contents('http...'))===FALSE){
$cnt ;
}
以上方法对付超时已经OK了。接下来演示一下用file_get_contents实现Post,如下:
PHP程式码
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.example.com', $data);
注意档案头的Set_time_out否则整个档案都得超时了
file_get_contents — 将整个文件读入一个字符串
说明
string file_get_contents ( string $filename [, bool $use_include_path [, resource $context [, int $offset [, int $maxlen ] ]]] )
和file() 一样,只除了file_get_contents() 把文件读入一个字符串。将在参数 offset 所指定的位置开始读取长度为 maxlen 的内容。如果失败,file_get_contents() 将返回 FALSE。
file_get_contents() 函数是用来将文件的内容读入到一个字符串中的首选方法。如果操作系统支持还会使用内存映射技术来增强性能。
Note: 如果要打开有特殊字符的 URL (比如说有空格),就需要使用 urlencode() 进行 URL 编码。
Note: context 参数可以用 NULL 来忽略。
file_get_contents() 读取一个文件中的内容,包括远程文件!!
file_get_contents() 函数是用来将文件的内容读入到一个字符串中的首选方法!!
< ?php
echo file_get_contents('www.baidu.com');
?>