PHP 获取网页内容的三种方法

抓取到的内容在通过正则表达式做一下过滤就得到了你想要的内容。

file_get_contents() 把整个文件读入一个字符串中。

<meta charset="utf-8">  
<?php 
$url = "http://onestopweb.iteye.com/"; 
$contents = file_get_contents($url); 
//如果出现中文乱码使用下面代码 
//$getcontent = iconv("gb2312", "utf-8",$contents); 
echo $contents; 
?>

curl_init() 初始化一个新的会话,返回一个cURL句柄,供curl_setopt(), curl_exec()和curl_close() 函数使用。

<meta charset="utf-8">  
<?php 
$url = "http://onestopweb.iteye.com/"; 
$ch = curl_init(); 
$timeout = 5; 
curl_setopt($ch, CURLOPT_URL, $url); 
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $timeout); 
//在需要用户检测的网页里需要增加下面两行 
//curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_ANY); 
//curl_setopt($ch, CURLOPT_USERPWD, US_NAME.":".US_PWD); 
$contents = curl_exec($ch); 
curl_close($ch); 
echo $contents; 
?> 

fopen->fread->fclose 文件流
fopen() 函数打开文件或者 URL。
fread() 函数读取文件。
fclose() 函数关闭一个打开文件。

<meta charset="utf-8">  
<?php 
$handle = fopen ("http://onestopweb.iteye.com/", "rb"); 
$contents = ""; 
do { 
	$data = fread($handle, 1024); 
	if (strlen($data) == 0) { 
		break; 
	} 
	$contents .= $data; 
} while(true); 
fclose ($handle); 
echo $contents; 
?> 

PS:
1.使用file_get_contents和fopen必须空间开启allow_url_fopen。方法:编辑php.ini,设置allow_url_fopen = On,allow_url_fopen关闭时fopen和file_get_contents都不能打开远程文件。
2.使用curl必须空间开启curl。方法:windows下修改php.ini,将extension=php_curl.dll前面的分号去掉,而且需要拷贝ssleay32.dll和libeay32.dll到 C:\Windows\system 或者 C:\Windows\System32。

如图:

 

我的系统是WIN7的64位,把两个dll文件放在这个文件夹中就起效果了。

 

猜你喜欢

转载自onestopweb.iteye.com/blog/2333612