当前位置:首页 > PHP教程 > php应用 > 列表

PHP7 preg_replace 出错及解决办法

发布:smiling 来源: PHP粉丝网  添加日期:2022-05-19 09:27:25 浏览: 评论:0 

在本篇文章里小编给大家整理的是一篇关于PHP7 preg_replace 出错及解决办法,有需要的朋友们可以跟着学习下。

问题描述:

PHP7废弃了preg_replace?

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

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

但是到php7中就报错了

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

相关代码

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

问题分析:

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

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

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

知识点扩展:

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

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

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

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

  1. $source_content = preg_replace($search.'e'"'" 
  2. $this->_quote_replace($this->left_delimiter) . 'php' 
  3. "' . str_repeat(\"\n\", substr_count('\\0', \"\n\")) .'" 
  4. $this->_quote_replace($this->right_delimiter) 
  5. "'" 
  6. $source_content); 

可以把smarty模板修改成这个

  1. $source_content = preg_replace_callback($searchfunction ($matches){ 
  2. $str=""
  3. $str.=$this->_quote_replace($this->left_delimiter) . 'php'
  4. $str.=str_repeat("\\n\\", substr_count($matches[1], "\\n\\")); 
  5. $str.=$this->_quote_replace($this->right_delimiter); 
  6. return $str
  7. }, $source_content);

Tags: preg_replace

分享到: