教程集 www.jiaochengji.com
教程集 >  脚本编程  >  php  >  正文 php写的文章采集URL补全函数(FormatUrl)

php写的文章采集URL补全函数(FormatUrl)

发布时间:2015-06-13   编辑:jiaochengji.com
采集文章时会经常遇到页面里的路径是 “相对路径” 或 “绝对根路径” 不是“绝对全路径”就无法收集URL。此时就需要对代码进行格式化,把所有的超链接都格式化一遍,然后就可以直接收集到正确的URL了。

采集文章时会经常遇到页面里的路径是 “相对路径” 或 “绝对根路径” 不是“绝对全路径”就无法收集URL。
此时就需要对代码进行格式化,把所有的超链接都格式化一遍,然后就可以直接收集到正确的URL了。

基础知识
1、相对路径:“../” “./” 或者前面什么都不加
2、绝对根路径:/path/xxx.html
3、绝对全路径:http://www.xxx.com/path/xxx.html
还是来看例子吧。
 

复制代码 代码如下:
<?php
$surl="http://www.jiaochengji.com/";
$gethtm = '<a href="/index.htm">首页</a><a href="Resolvent/index.htm">解决方案</a>';
echo formaturl($gethtm,$surl);
?>

输出:<a href="http://www.jiaochengji.com/index.htm">首页</a><a href="http://www.jiaochengji.com/Resolvent/index.htm">解决方案</a>
--------- 演示实例 ------------
原始路径代码:http://www.newnew.cn/newnewindex.aspx
输出演示代码:http://www.maifp.com/aaa/test.php
函数代码:
 

复制代码 代码如下:
<?php
function formaturl($l1,$l2){
if (preg_match_all("/(<img[^>]+src=\"([^\"]+)\"[^>]*>)|(<a[^>]+href=\"([^\"]+)\"[^>]*>)|(<img[^>]+src='([^']+)'[^>]*>)|(<a[^>]+href='([^']+)'[^>]*>)/i",$l1,$regs)){
foreach($regs[0] as $num => $url){
$l1 = str_replace($url,lIIIIl($url,$l2),$l1);
}
}
return $l1;
}
function lIIIIl($l1,$l2){
if(preg_match("/(.*)(href|src)\=(.+?)( |\/\>|\>).*/i",$l1,$regs)){$I2 = $regs[3];}
if(strlen($I2)>0){
$I1 = str_replace(chr(34),"",$I2);
$I1 = str_replace(chr(39),"",$I1);
}else{return $l1;}
$url_parsed = parse_url($l2);
$scheme = $url_parsed["scheme"];if($scheme!=""){$scheme = $scheme."://";}
$host = $url_parsed["host"];
$l3 = $scheme.$host;
if(strlen($l3)==0){return $l1;}
$path = dirname($url_parsed["path"]);if($path[0]=="\\"){$path="";}
$pos = strpos($I1,"#");
if($pos>0) $I1 = substr($I1,0,$pos);
//判断类型
if(preg_match("/^(http|https|ftp):(\/\/|\\\\)(([\w\/\\\+\-~`@:%])+\.)+([\w\/\\\.\=\?\+\-~`@\':!%#]|(&)|&)+/i",$I1)){return $l1; }//http开头的url类型要跳过
elseif($I1[0]=="/"){$I1 = $l3.$I1;}//绝对路径
elseif(substr($I1,0,3)=="../"){//相对路径
while(substr($I1,0,3)=="../"){
$I1 = substr($I1,strlen($I1)-(strlen($I1)-3),strlen($I1)-3);
if(strlen($path)>0){
$path = dirname($path);
}
}
$I1 = $l3.$path."/".$I1;
}
elseif(substr($I1,0,2)=="./"){
$I1 = $l3.$path.substr($I1,strlen($I1)-(strlen($I1)-1),strlen($I1)-1);
}
elseif(strtolower(substr($I1,0,7))=="mailto:"||strtolower(substr($I1,0,11))=="javascript:"){
return $l1;
}else{
$I1 = $l3.$path."/".$I1;
}
return str_replace($I2,"\"$I1\"",$l1);
}
?>

您可能感兴趣的文章:
php写的文章采集URL补全函数(FormatUrl)
PHP采集器的简单示例代码
php采集远程图片的思路与实现代码
phpQuery采集网页内容的示例代码
通过正则格式化url查询字符串的代码
php采集程序
PHP采集远程图片的实例代码
PHP MYSQL开发 视频教程
PHP数据采集程序采集天气网数据实例演示
PHP 采集图片函数一例

关键词: php 采集  php采集代码   
[关闭]
~ ~