前面介绍过js把文本链接转换成A标签,现在看一个php的方法,这个是在 Silva 代码的基础上修改的,如果有不完善的地方大家可提出来.
需要提取的内容如下:
<a href="http://baidu.com">http://baidu.com</a>这是第一个A标签,
<a href="http://blog.baidu.com">成长脚印-专注于互联网发展</a>这是第二个A标签。
http://www.phpfensi.com这是第一个需要被提取的URL地址,
http://blog.baidu.com这是第二个需要被提取的URL地址'。
<img border="0" alt="" src="http://baidu.com/css/sitelogo_zh-cn.gif">,这是一个IMG标签
类似微博中的自动提取URL为超链接地址,即将红色标记的内容提取出来添加A标签,转换成真正的超链接,网上搜索了很久,没有找到一个切实可行的解决方案,大都只是简单的提取URL(A标签和IMG标签内的地址也被提取替换了),并不能满足以上需求,正则表达式中也没发现能够实现提取时过滤掉A标签的方法,于是转换了一下思路,即先将所有的A标签和IMG标签正则替换为某一个统一的标记,然后再提取URL地址替换为超链接,最后再将统一的标记还原替换为以前的A标签和IMG标签便解决了,代码如下:
- function linkAdd($content){
-
- preg_match_all('/<a.*?href=".*?".*?>.*?</a>/i',$content,$linkList);
- $linkList=$linkList[0];
- $str=preg_replace('/<a.*?href=".*?".*?>.*?</a>/i','<{link}>',$content);
-
-
- preg_match_all('/<img[^>]+>/im',$content,$imgList);
- $imgList=$imgList[0];
- $str=preg_replace('/<img[^>]+>/im','<{img}>',$str);
-
-
- $str=preg_replace('(((f|ht){1}tp://)[-a-zA-Z0-9@:%_/+.~#?&//=]+)','<a href="\0" target="_blank">\0</a>',$str);
-
-
- $arrLen=count($linkList);
- for($i=0;$i<$arrLen;$i++){
- $str=preg_replace('/<{link}>/',$linkList[$i],$str,1);
- }
-
-
- $arrLen2=count($imgList);
- for($i=0;$i<$arrLen2;$i++){
- $str=preg_replace('/<{img}>/',$imgList[$i],$str,1);
- }
-
- return $str;
- }
-
- $content='
- <a href="http://baidu.com">http://baidu.com</a>这是第一个A标签,
- <a href="http://blog.baidu.com">成长脚印-专注于互联网发展</a>这是第二个A标签。
- http:
- http:
- <img border="0" alt="" src="http://baidu.com/css/sitelogo_zh-cn.gif">,这是一个IMG标签';
- echo linkAdd($content);
返回的内容为:
<a href="http://baidu.com">http://baidu.com</a>这是第一个A标签, <a href="http://blog.baidu.com">成长脚印-专注于互联网发展</a>这是第二个A标签。 <a href="http://www.phpfensi.com" target="_blank">http://www.phpfensi.com</a>这是第一个需要被提取的URL地址, <a href="http://blog.baidu.com" target="_blank">http://blog.baidu.com</a>这是第二个需要被提取的URL地址。
<img border="0" alt="" src="http://baidu.com/css/sitelogo_zh-cn.gif">,这是一个IMG标签
即为我们想要的内容.
例2,代码如下:
-
-
-
-
-
-
-
-
-
-
-
-
-
- function replace_URLtolink($text) {
-
- $urls = array();
-
-
- $scheme = '(https?://|ftps?://)?';
- $www = '([w]+.)';
- $ip = '(d{1,3}.d{1,3}.d{1,3}.d{1,3})';
- $name = '([w0-9]+)';
- $tld = '(w{2,4})';
- $port = '(:[0-9]+)?';
- $the_rest = '(/?([w#!:.?+=&%@!-/]+))?';
- $pattern = $scheme.'('.$ip.$port.'|'.$www.$name.$tld.$port.')'.$the_rest;
- $pattern = '/'.$pattern.'/is';
-
-
- $c = preg_match_all($pattern, $text, $m);
-
- if ($c) {
- $urls = $m[0];
- }
-
-
- if (! emptyempty($urls)) {
- foreach ($urls as $url) {
- $pos = strpos('http://', $url);
-
- if (($pos && $pos != 0) || !$pos) {
- $fullurl = 'http://'.$url;
- } else {
- $fullurl = $url;
- }
-
- $link = ''.$url.'';
-
- $text = str_replace($url, $link, $text);
- }
- }
-
- return $text;
- }
例一测试过,例二没有测试过大家测试一下看那个好用用那个吧. |