博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
file_get_contents()函数超时处理方法
阅读量:5920 次
发布时间:2019-06-19

本文共 1441 字,大约阅读时间需要 4 分钟。

file_get_contents将整个文件读入一个字符串

string file_get_contents ( string $filename [, bool $use_include_path [, resource $context [, int $offset [, int $maxlen ]]]] )

参数
描述
path
必需。规定要读取的文件。
include_path
可选。如果也想在 include_path 中搜寻文件的话,可以将该参数设为 "1"。
context
可选。规定文件句柄的环境。
context 是一套可以修改流的行为的选项。若使用 null,则忽略。
start
可选。规定在文件中开始读取的位置。该参数是 PHP 5.1 新加的。
max_length
可选。规定读取的字节数。该参数是 PHP 5.1 新加的。

 

在获取文件的 时候,可能会因为网络等因素,造成获取失败,这里介绍两种方法进行解决

一.增加超时的时间限制 

这里需要注意:set_time_limit只是设置你的PHP程序的超时时间,而不是file_get_contents函数读取URL的超时时间。真正的修改 file_get_contents延时可以用resource $context的timeout参数: 

array( 'method'=>"GET", 'timeout'=>60, ) ); $context = stream_context_create($opts);$html =file_get_contents('http://www.example.com', false, $context); ?>

 

其中,stream_context_create 作用:创建并返回一个文本数据流并应用各种选项,可用于fopen(),file_get_contents()等过程的超时设置、代理服务器、请求方式、头信息设置的特殊过程。 

函数原型:resource stream_context_create ([ array $options [, array $params ]] ) 

 

 

二、一次有延时的话那就多试几次

有时候失败是因为网络等因素造成,没有解决办法,但是可以修改程序,失败时重试几次,仍然失败就放弃,因为file_get_contents()如果失败将返回 FALSE,所以可以下面这样编写代码:

 

以上方法对付超时已经OK了。

有人发现了'method'=>”GET”,GET也可以设置成post,函数如下:

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);?>

 

转载地址:http://rgnvx.baihongyu.com/

你可能感兴趣的文章
内存空间的各个段
查看>>
Ubantu搭建FTP
查看>>
1147: 零起点学算法54——Fibonacc
查看>>
[笔记]Optical Fiber
查看>>
并发编程(二)—— CountDownLatch、CyclicBarrier和Semaphore
查看>>
spring源码深度解析—Spring的整体架构和环境搭建
查看>>
golang的reflect
查看>>
eclipse配置workspace背景颜色
查看>>
shiro 拦截器
查看>>
【尺取法】总结
查看>>
MySQL数据库插入中文乱码解决方法
查看>>
tornado+jsonrpc
查看>>
你最常用的构建和发布管理工具是什么
查看>>
Python之路【第九篇】:字符串与字节的相互转换以及2.7与3输出方式的不同
查看>>
第三堂课
查看>>
文件上传-------头像上传预览
查看>>
垃圾收集器与内存分配策略
查看>>
Html中编码格式的设置,及引入javascript、css的方法
查看>>
抽象类 VS 接口(2)
查看>>
JAVA---final
查看>>