[PHP学习教程 - 网络]002.获取网页内容(URL Content)
引言:获取网页内容是我们实现网页操作的基本之基本,今天这一讲,我们和大家讲一下基本请求网页内容的几种方法。
我们似乎每天都要做这样一件事情,打开一个浏览器,输入网址,回车,一个空白的页面顿时有了东西,它可能是百度之类的搜索页面,或是一个挤满了文字和图片的门户网站。
我们可以从三个方面理解这个过程,一个是浏览器,二个是服务器,第三个是浏览器和服务器之间通信的协议。
当然,我们今天不讲<网页请求过程 >
这一次,我们说一下如何用PHP代码请求网页内容。

获取网页内容方法
1.file_get_contents+[请求方式:GET]
<?php
$url = 'http://do.org.cn';
$html = file_get_contents($url);
echo $html;
?>
2.file_get_contents+[请求方式:POST]
无需Cookie操作,则使用以下方式:
<?php
$url = 'http://do.org.cn/upload.php';
$data = http_build_query(array('foo' => 'bar'));
$params = array(
'http' => array(
'method' => 'POST',
'content' => $data,
'header' =>
"Content-type: application/x-www-form-urlencoded\r\n" .
"Content-Length: " . strlen($data) . "\r\n"
)
);
$context = stream_context_create($params);
$html = @file_get_contents($url, '', $context);
有需Cookie操作,则在$params里的'header'添加下一行(类似如下文):
"cookie:cookie1=c1;cookie2=c2\r\n" ;
3.fopen+[请求方式:GET]
<?php
// 尝试打开网页
$fp = fopen($url, 'r');
// 获取报头信息
$header = stream_get_meta_data($fp);
while (!feof($fp)) {
$result .= fgets($fp, 1024);
}
fclose($fp);
// 输出结果
echo "url header: {$header} <br/>";
echo "url body: $result";
?>
.fopen+[请求方式:POST]
<?php
$data = http_build_query(array('foo1' => 'bar1', 'foo2' => 'bar2'));
$params = array(
'http' => array(
'method' => 'POST',
'content' => $data,
'header' => "Content-type: application/x-www-form-urlencoded\r\nCookie:cook1=c3;cook2=c4\r\n" .
"Content-Length: " . strlen($data) . "\r\n"
)
); $context = stream_context_create($params);
$fp = fopen('http://do.org.cn/upload.php', 'rb', false, $context);
$content = fread($fp, 1024);
fclose($fp);
echo $content;
?>
.fsockopen+[请求方式:GET]
用fsockopen函数打开网址URL,以GET方式请求完整的数据,包括header和body.
<?php
function get_url($url, $cookie=false) {
$url = parse_url($url);
$query = $url[path]. "?" .$url[query];
echo "Query:" . $query;
$fp = fsockopen($url[host], $url[port] ? $url[port] : 80, $errno, $errstr, 30);
if (!$fp) {
return false;
} else {
$request = "GET $query HTTP/1.1\r\n";
$request .= "Host: $url[host]\r\n";
$request .= "Connection: Close\r\n";
if ($cookie) {
$request.="Cookie: $cookie\r\n";
}
$request .= "\r\n";
fwrite($fp, $request);
while (!@feof($fp)) {
$result .= @fgets($fp, 1024);
}
fclose($fp);
return $result;
}
}
// 获取url的html部分,去掉header
function get_html($url, $cookie=false) {
$data = get_url($url, $cookie);
if ($data) {
$body = stristr($data, "\r\n\r\n");
$body = substr($body, 4, strlen($body));
return $body;
}
return false;
}
?>
.fsockopen+[请求方式:POST]
用fsockopen函数打开网址URL,以POST方式请求完整的数据,包括header和body.
<?php
function post_url($url, $data, $cookie, $referrer="") {
// parsing the given URL
$url_info = parse_url($url); // Building referrer
if ($referrer == "") { // if not given use this script as referrer
$referrer = "111";
} // making string from $data
foreach ($data as $key => $value) {
$values[] = "$key=" . urlencode($value);
}
$data_string = implode("&", $values); // Find out which port is needed - if not given use standard (=80)
if (!isset($url_info["port"])) {
$url_info["port"] = 80;
} // building POST-request:
$request .= "POST ".$url_info["path"]." HTTP/1.1\n";
$request .= "Host: ".$url_info["host"]."\n";
$request .= "Referer: $referer\n";
$request .= "Content-type: application/x-www-form-urlencoded\n";
$request .= "Content-length: ".strlen($data_string)."\n";
$request .= "Connection: close\n";
$request .= "Cookie: $cookie\n";
$request .= "\n";
$request .= $data_string."\n"; $fp = fsockopen($url_info["host"], $url_info["port"]);
fputs($fp, $request);
while (!feof($fp)) {
$result .= fgets($fp, 1024);
}
fclose($fp); return $result;
}
?>
.curl库
注意:使用curl库之前,需要查看一下php.ini是否已经打开了curl扩展.
<?php
$ch = curl_init();
$timeout = 5;
curl_setopt($ch, CURLOPT_URL, 'http://do.org.cn/');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
$content = curl_exec($ch);
curl_close($ch); echo $content;
?>

本站文章为宝宝巴士 SD.Team原创,转载务必在明显处注明:(作者官方网站:宝宝巴士)
转载自【宝宝巴士SuperDo团队】 原文链接: http://www.cnblogs.com/superdo/p/4805187.html
[PHP学习教程 - 网络]002.获取网页内容(URL Content)的更多相关文章
- [PHP学习教程 - 网络]002.$_SERVER["SCRIPT_NAME"]、$_SERVER["PHP_SELF"]、$_SERVER["QUERY_STRING"]、$_SERVER["REQUEST_URI"]介绍($_SERVER URL Infomation)
引言:在使用原生PHP的时候,对于URL路径的切割,如:域名,查询参数等等的提取,通常绝大多数兄弟会忽略$_SERVER中定义的内置常量的关系,这里为大家讲解一下. 常用的URL请求路径$_SERVE ...
- [PHP学习教程 - 网络]003.获得当前访问的页面URL(Current Request URL)
引言:获取当前请求的URL路径,自动判断协议(HTTP or HTTPS). 一句话的事情,下面直接上高清无MSK的精妙代码! 功能函数 获得当前请求的页面路径(URL)地址 语法:$url = ge ...
- [PHP学习教程 - 网络]001.下载/采集远程文件到本地(Download File)
引言:如何把http://mzitu.com里的图片全部下载下来呢? 一身浩然正气的AC陷入的深思.... 当然这里涉及到的功能有线程,网页请求,页面提取,下载图片等等.今天,我们先讲一下如何下载文件 ...
- [PHP学习教程 - 文件]002.修改上传文件大小限制(File Upload Limit)
引言:通常大家直装xampp之后,默认的文件上传大小应该被设定成2M左右,这个时候如果上传超过2M的东西,就会报错,让人非常尴尬.如何修改呢? 导航索引: 概念 FTP常用API FTP封装类 其他 ...
- [PHP学习教程 - 类库]002.FTP操作(FTP)
引言:FTP是大家上传至站点服务器必须要使用的协议.现在常用的FTP客户端工具也很多,如:8uftp,FlashFXP,....但是使用客户端工具就无法真正与自动化联系起来.所以今天,我们为大家讲一下 ...
- [PHP学习教程 - 文件]002.判断远程文件是否存在(Remote File Exists)
引言:项目过程当中碰到了类似流程这样的需求,对服务器上的文件进行依次操作,如:检查文件格式->检查文件是否有更新->处理更新->同步其他服务器等等 如果需求的操作是依赖于远程文件是否 ...
- [PHP学习教程 - 网络]004.模拟发送HTTP请求[GET/POST](HTTP Simulator)
引言:经常在开发期间,客户端与服务端的调试都是借助于真实的容器返回.尤其是在处理到POST时,通常刚刚入门的兄弟姐妹就一定要借助容器.今天,我们就来处理一下模拟HTTP. 本文列举了常见的四种请求方式 ...
- [PHP学习教程 - 系统]002.模拟守护进程(Daemon)-程序永远在后台运行
引言:如何模拟那些自动轮循的服务,像守护进程(Daemon)那样,可以一直执行,永不停歇呢! Come on! Do it! Do! Do! Do!.... 使用接口: int ignore_user ...
- C# 网络编程之webBrowser获取网页url和下载网页中图片
该文章主要是通过C#网络编程的webBrowser获取网页中的url并简单的尝试瞎子啊网页中的图片,主要是为以后网络开发的基础学习.其中主要的通过应用程序结合网页知识.正则表达式实现浏览.获取url. ...
随机推荐
- 树形dp compare E - Cell Phone Network POJ - 3659 B - Strategic game POJ - 1463
B - Strategic game POJ - 1463 题目大意:给你一棵树,让你放最少的东西来覆盖所有的边 这个题目之前写过,就是一个简单的树形dp的板题,因为这个每一个节点都需要挺好处 ...
- Java基础-数据类型的拓展
整数拓展:进制 二进制 0b开头 十进制 八进制 0开头 十六进制 0x开头 0~9 A~F 16 int i = 10; int i1 = 010;//八进制 0开头 int i2 = 0x10;/ ...
- Spring官网阅读(六)容器的扩展点(一)BeanFactoryPostProcessor
之前的文章我们已经学习完了BeanDefinition的基本概念跟合并,其中多次提到了容器的扩展点,这篇文章我们就开始学习这方面的知识.这部分内容主要涉及官网中的1.8小结.按照官网介绍来说,容器的扩 ...
- 你离高薪 offer 只差一个Redis入门,我是认真的
说起来,可能有些小伙伴会不相信,我是第一次用 Redis,真的.因为公司小,业务量小,Redis 根本派不上用场.不过,最近打算把系统升级一下,顺带把当下时髦的技术入个门,"与时俱进&quo ...
- ES[7.6.x]学习笔记(八)数据的增删改
在前面几节的内容中,我们学习索引.字段映射.分析器等,这些都是使用ES的基础,就像在数据库中创建表一样,基础工作做好以后,我们就要真正的使用它了,这一节我们要看看怎么向索引里写入数据.修改数据.删除数 ...
- Qt数据库总结
使用Qt SQL库 头文件: #include <QtSql> 项目: QT += sql 常用类 QSqlDatabase:数据库的连接打开等操作 QSqlQuery:执行语句,获取结果 ...
- 设计模式之GOF23适配器模式
结构型模式 核心作用:是从程序的结构上实现松耦合,从而可以扩大整体的 类结构,用来解决更大的问题 适配器模式adapter 实际生活中的例子:转换器 适配器的两种方式: 1,类适配器(继承) /**需 ...
- 【Effective Java】第二章-创建和销毁对象——1.考虑用静态工厂方法代替构造器
静态工厂方法的优点: 可以赋予一个具有明确含义的名称 可以复用唯一实例,不必每次新建 可以返回原实例类型的子类对象 可以在返回泛型实例时更加简洁 缺点: 类如果不含有共有的或者受保护的构造器,就不能被 ...
- python-修改文件
1.修改文件1 # fw = open('username','w')# fw.write('hhhh')# fw.flush() #强制把缓冲区里面的数据写到磁盘上1.简单粗暴直接# 1.打开一 ...
- 你了解C#的协变和逆变吗
从C# 4.0开始,泛型接口和泛型委托都支持协变和逆变,由于历史原因,数组也支持协变. 里氏替换原则:任何基类可以出现的地方,子类一定可以出现. 协变(out) 协变:即自然的变化,遵循里氏替换原则, ...