我被困住了,因为preg_matching并不总是那么容易,因为我完全不熟悉它。
我正在尝试更换所有的
例如:
<a href="www.site1.com">Site1</a> => <a href="http://example.com?u=www.site1.com">Site1</a>
但&lt; a href可以用很多方式写出来; HREF或A href或双倍间隔&lt; A href等...我该如何管理它。请记住,性能是关键
我用str_replace尝试了以下内容,但当然并未涵盖所有&lt; a href(大写非大写版本)。
$str = '<a href="www.sitename1.com">sitename1</a><br /><a href="www.sitename2.com">sitename2</a><br /><A HREF="www.sitename3.com">sitename3</a>';
$Replace = str_replace('<a href="', '<a href="https://example.com/&i=1243123&r=', $str);
echo $Replace
答案 0 :(得分:2)
试试这个(PHP 5.3 +):
$link = preg_replace_callback('#<a(.*?)href="(.*?)"(.*?)>#is', function ($match) {
return sprintf(
'<a%shref="%s"%s>',
$match[1],
'http://example.com?u=' . urlencode($match[2]),
$match[3]
);
}, '<a href="www.site1.com">Site1</a>');
echo $link;
答案 1 :(得分:1)
唯一完全可靠的方法是使用正确的HTML解析器。
令人高兴的是,PHP内置了一个。
您首先使用DomDocument的loadHTML
函数加载HTML:http://php.net/manual/en/domdocument.loadhtml.php
然后使用XPath搜索已解析的树并操纵A标记:http://php.net/manual/en/domxpath.query.php