首页 > php代码 > php将URL地址转化为完整的A标签链接代码

php将URL地址转化为完整的A标签链接代码

前面介绍过js把文本链接转换成A标签,现在看一个php的方法,这个是在 Silva 代码的基础上修改的,如果有不完善的地方大家可提出来。

需要提取的内容如下:

<a href="http://baidu.com">http://baidu.com</a>这是第一个A标签,

<a href="http://blog.baidu.com">成长脚印-专注于互联网发展</a>这是第二个A标签。

http://www.phprm.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标签的方法。于是转换了一下思路,&ldquo;曲线救国&rdquo;。即,先将所有的A标签和IMG标签正则替换为某一个统一的标记,然后再提取URL地址替换为超链接,最后再将统一的标记还原替换为以前的A标签和IMG标签便解决了。

<?php
function linkAdd($content) {
    //提取替换出所有A标签(统一标记<{link}>)
    preg_match_all('/<a.*?href=".*?".*?>.*?</a>/i', $content, $linkList);
    $linkList = $linkList[0];
    $str = preg_replace('/<a.*?href=".*?".*?>.*?</a>/i', '<{link}>', $content);
    //提取替换出所有的IMG标签(统一标记<{img}>)
    preg_match_all('/<img[^>]+>/im', $content, $imgList);
    $imgList = $imgList[0];
    $str = preg_replace('/<img[^>]+>/im', '<{img}>', $str);
    //提取替换标准的URL地址
    $str = preg_replace('(((f|ht){1}tp://)[-a-zA-Z0-9@:%_/+.~#?&//=]+)', '<a href="" target="_blank"></a>', $str);
    //还原A统一标记为原来的A标签
    $arrLen = count($linkList);
    for ($i = 0; $i < $arrLen; $i++) {
        $str = preg_replace('/<{link}>/', $linkList[$i], $str, 1);
    }
    //还原IMG统一标记为原来的IMG标签
    $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://www.phprm.com这是第一个需要被提取的URL地址,
http://blog.baidu.com这是第二个需要被提取的URL地址。
<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.phprm.com" target="_blank">http://www.phprm.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,

<?php
/**
 * PHP 版本 在 Silva 代码的基础上修改的
 * 将URL地址转化为完整的A标签链接代码
 */
/** =============================================
 NAME        : replace_URLtolink()
 VERSION     : 1.0
 AUTHOR      : J de Silva
 DESCRIPTION : returns VOID; handles converting
 URLs into clickable links off a string.
 TYPE        : functions
 =============================================
 */
function replace_URLtolink($text) {
    // grab anything that looks like a URL...
    $urls = array();
    // build the patterns
    $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';
    // Get the URLs
    $c = preg_match_all($pattern, $text, $m);
    if ($c) {
        $urls = $m[0];
    }
    // Replace all the URLs
    if (!empty($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;
}
?>

例一测试过,例二没有测试过大家测试一下看那个好用用那个吧。


本文地址:http://www.phprm.com/code/57143.html

转载随意,但请附上文章地址:-)

标签:foreach preg_match

相关文章

发表留言