我被困住了,因为preg_matching并不总是那么容易,因为我对它完全不熟悉。
我在试着替换所有
例如:
<a href="www.site1.com">Site1</a> => <a href="http://example.com?u=www.site1.com">Site1</a>但是
我已经在str_replace中尝试了下面的内容,但是当然,这并不包括所有的
$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发布于 2015-01-12 20:31:11
试试这个(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;发布于 2015-01-12 20:28:27
唯一完全可靠的方法是使用适当的HTML解析器。
幸运的是,PHP有一个内置的。
首先使用DomDocument的loadHTML函数加载HTML:http://php.net/manual/en/domdocument.loadhtml.php
然后使用XPath搜索已解析的树,并操作A标记:http://php.net/manual/en/domxpath.query.php
https://stackoverflow.com/questions/27910133
复制相似问题