1

我使用以下内容查找 $content 中的所有 URL

 $content = preg_match_all( '/(http[s]?:[^\s]*)/i', $content, $links );

但这将取决于http://.http://www.google.com/some/path

我的问题是:

1 - 我怎样才能修改它以点击仅以开头的链接www,例如www.google.com

2 - 主要目的是找到链接,并将它们替换为从另一个函数返回的值。我尝试了 preg_match_callback() ,但它不起作用(可能使用错误..

$content = preg_replace_callback(
           "/(http[s]?:[^\s]*)/i",
            "my_callback",
            $content);

function my_callback(){

// do a lot of stuff independently of preg_replace
// adding to =.output...

return $output;
}

现在,在我的逻辑(这可能是错误的)中,所有匹配项$content都将替换为$output. 我究竟做错了什么 ?

(请不要使用匿名函数 - 我正在旧服务器上测试)

编辑我- 在评论后,试图澄清更多细节

function o99_simple_parse($content){

$content = preg_replace_callback( '/(http[s]?:[^\s]*)/i', 'o99_simple_callback', $content );


return $content;
}

打回来 :

function o99_simple_callback($url){
    // how to get the URL which is actually the match? and width ??
        $url = esc_url_raw( $link );
        $url_name = parse_url($url); 
        $url_name = $description = $url_name['host'];// get rid of http://..
        $url = 'http://something' .  urlencode($url)   . '?w=' . $width ; 
        return $url; // what i really need to replace 
    }
4

1 回答 1

3

要修改您已经必须允许以 开头的 URL 的正则表达式www,您只需编写以下代码:

/((http[s]?:|www[.])[^\s]*)/i
  +         ++++++++
于 2013-03-27T02:54:44.857 回答