PHP抓取远程网站数据的代码
Ⅰ .抓取远程网页标题的例子:
以下是代码片段:
?php
/*
+---
+抓取网页标题的代码,直接拷贝本代码片段,另存为.php文件执行即可.+---
*/error_reporting(7) ;
$file=fopen(""r") ;if( !$file) {echo"fontcolor=redUnabletoopenremotefile./font\n";exit;
}while(!feof($file) ) {
$line=fgets($file, 1024) ;if(eregi ("title(.*)/title", $line, $out) ) {
$title=$out[1] ;echo"". $title. "";break;
}
}fclose($file) ;
//End
?
Ⅱ.抓取远程网页HTML代码的例子:
以下是代码片段:
?php
/*
+--
+DNSingSprider
+--
*/
$fp=fsockopen("www.dnsing.com",80, $errno, $errstr,30) ;if(!$fp) {echo"$errstr($errno)br/\n";
}else{
$out="GET/HTTP/1. 1\r\n";
$out.="Host:www.dnsing.com\r\n";
$out.="Connection:Close\r\n\r\n";fputs($fp, $out) ;while(!feof($fp) ) {echofgets($fp, 128) ;
}fclose($fp) ;
}
//End
?
以上两个代码片段都直接Copy回去运行就知道效果了,上面的例子只是抓取网页数据的雏形,要使其更适合自己的使用,情况有各异.所以,在此各位程序爱好者自己好好研究一下吧.
===
稍微有点意义的函数
是:get_content_by_socket() ,get_url () ,get_content_url () ,get_content_object几个函数也许能够给你点什么想法。
?php
//获取所有内容url保存到文件
functionget_index($save_file, $prefix="index_") {
$count=68;
$i=1 ;if(file_exists($save_file) )@unlink($save_file) ;
$fp=fopen($save_file, "a+")ordie("Open". $save_file. "failed") ;while($i$count) {
$url=$prefix. $i. ".htm";echo"Get". $url. ". ";
$url_str=get_content_url (get_url ($url) ) ;echo"OK\n";fwrite($fp, $url_str) ;
++$i ;
}fclose($fp) ;
}
//获取目标多媒体对象functionget_object($url_file, $save_file, $split="|--:*:--|") {if(!file_exists($url_file) )die($url_file. "notexist") ;$file_arr=file($url_file) ;
if(! is_array($file_arr) | |empty($file_arr) )die($url_file. "notcontent") ;
$url_arr=array_unique($file_arr) ;if(file_exists($save_file) )@unlink($save_file) ;
$fp=fopen($save_file, "a+")ordie("Opensavefile". $save_file. "failed") ;foreach($url_arras$url) {if(empty($url) )continue;echo"Get". $url. ". ";
$html_str=get_url ($url) ;echo$html_str;echo$url;exit;
$obj_str=get_content_object($html_str) ;echo"OK\n";fwrite($fp, $obj_str) ;
}fclose($fp) ;
}
//遍历目录获取文件内容
functionget_dir($save_file, $dir) {
$dp=opendir($dir) ;if(file_exists($save_file) )@unlink($save_file) ;
$fp=fopen($save_file, "a+")ordie("Opensavefile". $save_file. "failed") ;while( ($file=readdir($dp) ) !=false) {if($file!=". "&&$file!=". ") {echo"Readfile". $file. ". ";
$file_content=file_get_contents($dir. $file) ;
$obj_str=get_content_object($file_content) ;echo"OK\n";fwrite($fp, $obj_str) ;
}
}fclose($fp) ;
}
//获取指定url内容functionget_url ($url) {
$reg='/^http:\/\/[^\/] .+$/' ;if(!preg_match($reg, $url) )die($url. "invalid") ;
$fp=fopen($url, "r")ordie("Openurl:". $url. "failed. ") ;while($fc=fread($fp,8192) ) {
$content.=$fc;
}fclose($fp) ;if(empty($content) ) {die("Geturl:". $url. "contentfailed. ") ;
}return$content;
}
//使用socket获取指定网页functionget_content_by_socket($url, $host) {
$fp=fsockopen($host,80)ordie("Open". $url. "failed") ;
$header="GET/". $url. "HTTP/1. 1\r\n";
$header.="Accept:*/*\r\n";
$header.="Accept-Language:zh-cn\r\n";
$header.="Accept-Encoding:gzip,deflate\r\n";
$header.="User-
Agent:Mozilla/4.0(compatible;MSIE6.0;WindowsNT5. 1 ;SV1 ;Maxthon;InfoPath. 1 ; .NETCLR2.0.50727)\r\n";
$header.="Host:". $host. "\r\n";
$header.="Connection:Keep-Alive\r\n";
//$header.="Cookie:cnzz02=2;rtime=1 ; ltime=1148456424859;cnzz_eid=56601755-\r\n\r\n";
$header.="Connection:Close\r\n\r\n";fwrite($fp, $header) ;while(!feof($fp) ) {
$contents.=fgets($fp,8192) ;
}fclose($fp) ;return$contents;
}
//获取指定内容里的urlfunctionget_content_url ($host_url, $file_contents) {
//$reg='/^ (#|javascript.*?|ftp:\/\/.+|http:\/\/.+| .*?href.*?|play.*?| index.*?| .*?asp)+$/i' ;
//$reg='/^ (down.*?\.html |\d+_\d+\.htm.*?)$/i' ;
$rex="/( [hH] [rR] [eE] [Ff])\s*=\s*[' \"]*( [^' \"\s]+) [\"' ]*\s*/i";
$reg='/^ (down.*?\.html)$/i' ;preg_match_all ($rex, $file_contents, $r) ;
$result="";//array() ;
foreach($ras$c) {if(is_array($c) ) {foreach($cas$d) {if(preg_match($reg, $d) ) {$result.=$host_url. $d. "\n"; }}
}
}return$result;
}
//获取指定内容中的多媒体文件functionget_content_object($str, $split="|--:*:--|") {$regx="/href\s*=\s*[' \"]*( [^' \"\s]+) [\"' ]*\s*(b.*?\/b)/i";preg_match_all ($regx, $str, $result) ;if(count($result)==3) {
$result[2]=str_replace("b多媒体:", "", $result[2]) ;
$result[2]=str_replace("/b", "", $result[2]) ;
$result=$result[1] [0] . $split. $result[2] [0] . "\n";
}return$result;
从介绍看啊,新增的HostYun 俄罗斯机房采用的是双向CN2线路,其他的像香港和日本机房,均为国内直连线路,访问质量不错。HostYun商家通用九折优惠码:HostYun内存CPUSSD流量带宽价格(原价)购买地址1G1核10G300G/月200M28元/月购买链接1G1核10G500G/月200M38元/月购买链接1G1核20G900G/月200M68元/月购买链接2G1核30G1500G/月...
提速啦的来历提速啦是 网站 本着“良心 便宜 稳定”的初衷 为小白用户避免被坑 由赣州王成璟网络科技有限公司旗下赣州提速啦网络科技有限公司运营 投资1000万人民币 在美国Cera 香港CTG 香港Cera 国内 杭州 宿迁 浙江 赣州 南昌 大连 辽宁 扬州 等地区建立数据中心 正规持有IDC ISP CDN 云牌照 公司。公司购买产品支持3天内退款 超过3天步退款政策。提速啦的市场定位提速啦主...
螢光云官網萤光云成立于2002年,是一家自有IDC的云厂商,主打高防云服务器产品。在国内有福州、北京、上海、台湾、香港CN2节点,还有华盛顿、河内、曼谷等海外节点。萤光云的高防云服务器自带50G防御,适合高防建站、游戏高防等业务。本次萤光云中秋云活动简单无套路,直接在原有价格上砍了一大刀,最低价格16元/月,而且有没有账户限制,新老客户都可以买,就是直接满满的诚意给大家送优惠了!官网首页:www....