PHP7 preg_replace 出错及解决办法

2022/02/05 00:44
阅读数 201

问题描述:

PHP7废弃了preg_replace?

原本是中php5中处理url中后面参数替换清除的,代码如下

1
$url = preg_replace( '/([?&])src=[^&]+(&?)/e' , '"$2"==""?"":"$1"' , $url );

但是到php7中就报错了

需要用preg_replace_callback来替换,请问该咋办?

相关代码

1
$url = preg_replace( '/([?&])src=[^&]+(&?)/e' , '"$2"==""?"":"$1"' , $url );

问题分析:

e 修饰符因为存在安全隐患 自 5.3 开始就已经标记为了待移除的内容。

转而接替的是 preg_replace_callback,此方法第二个参数为一个回调函数,回调函数会自动传入比配的分组作为参数。在回调函数内部通过数组下标访问匹配组。(手机码字 未格式化代码)

1
2
3
preg_replace_callback( '/([?&])src=[^&]+(&?)/' , function ( $matches ){
     return $matches [2]== "" ? "" : $matches [1];
}, $url );

知识点扩展:

PHP7已经删除了preg_replace的e修饰符

官网提示是这样的,对/e修饰符的支持已删除。请改用preg_replace_callback()

原因是/e 修正符使 preg_replace() 将 replacement 参数当作 PHP 代码(在适当的逆向引用替换完之后),会被一句话后门使用

看看smarty中是也是这样用的,也是存在问题

1
2
3
4
5
6
7
8
9
10
11
12
13
14
$source_content = preg_replace( $search . 'e' , "'"
. $this ->_quote_replace( $this ->left_delimiter) . 'php'
. "' . str_repeat(\"\n\", substr_count('\\0', \"\n\")) .'"
. $this ->_quote_replace( $this ->right_delimiter)
. "'"
, $source_content );
可以把smarty模板修改成这个
$source_content = preg_replace_callback( $search , function ( $matches ){
$str = "" ;
$str .= $this ->_quote_replace( $this ->left_delimiter) . 'php' ;
$str .= str_repeat ( "\\n\\" , substr_count( $matches [1], "\\n\\" ));
$str .= $this ->_quote_replace( $this ->right_delimiter);
return $str ;
}, $source_content );

 

展开阅读全文
加载中
点击引领话题📣 发布并加入讨论🔥
0 评论
0 收藏
0
分享
返回顶部
顶部