php新版本废弃 preg_replace /e 修饰符

最近服务器php版本升级到了 5.6  发现出了很多警告

preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead

一开始没注意,后来发现 很多这样的警告,于是网上查了下 发现 php5.5版本以上 就废弃了  preg_replace   函数中 /e 这个修饰符  /e 这个修饰符的意思 就是让 正则替换的 时候 替换规则 支持 php 代码

那么 应该怎么办呢

其实 只要 把 preg_replace 里面 有 /e 修饰符的代码 修改成  preg_replace _callback  然后重新写下就好了

例子

比如说

preg_replace("/([A-Z])/e", "'_' . strtolower('\\1')", $str)

修改成

preg_replace_callback('/([A-Z])/',
                      function ($matches) {
                        return '_' . strtolower($matches[0]);
                      },
                      $str)

即可

这里特别警告 修改后 /([A-Z])/e  最后一个  e   一定要去掉 不然就出错了

下面再看一个稍微复杂点的例子

$patterns       = '/'.$begin.$parseTag.$n1.'\/(\s*?)'.$end.'/eis';
$replacement    = "\$this->parseXmlTag('$tagLib','$tag','$1','')";
$content        = preg_replace($patterns, $replacement,$content);

这个替换 使用了 类里面的自定义方法 如果 你再 用匿名函数直接套的话 会提示 错误 因为 匿名函数上下文里面 并没有 该方法和 该变量  所以 要用 use() 来引入  同时 注意 一定要 把  正则里面 e  去掉

$that = $this;
$patterns       = '/'.$begin.$parseTag.$n1.'\/(\s*?)'.$end.'/is';
$content=preg_replace_callback($patterns, function($matches) use($tagLib,$tag,$that){
    return $that->parseXmlTag($tagLib,$tag,$matches[1],'');
},$content);

这里 用 $thit  代替 $this;  好了 今天先记录到这里吧 。

小烟原创,转载请注明出处!

时间: 2024-08-08 19:23:26

php新版本废弃 preg_replace /e 修饰符的相关文章

php新版本号废弃 preg_replace /e 修饰符

近期serverphp版本号升级到了 5.6  发现出了非常多警告 preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead 一開始没注意.后来发现 非常多这种警告,于是网上查了下 发现 php5.5版本号以上 就废弃了  preg_replace   函数中 /e 这个修饰符  /e 这个修饰符的意思 就是让 正则替换的 时候 替换规则 支持 php 代码 那么 应该怎么办呢 事实上 仅仅要

关于thinkhphp3.1中废弃 preg_replace /e 修饰符

警告:preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead 网上查了下 发现 php5.5版本以上 就废弃了  preg_replace   函数中 /e 这个修饰符 /e 这个修饰符的意思 就是让 正则替换的 时候 替换规则 支持 php 代码 解决方案:只要 把 preg_replace 里面 有 /e 修饰符的代码 修改成  preg_replace _callback  然后重新写

慎用preg_replace危险的/e修饰符(一句话后门常用)

要确保 replacement 构成一个合法的 PHP 代码字符串,否则 PHP 会在报告在包含 preg_replace() 的行中出现语法解析错误 preg_replace函数原型: mixed preg_replace ( mixed pattern, mixed replacement, mixed subject [, int limit]) 特别说明: /e 修正符使 preg_replace() 将 replacement 参数当作 PHP 代码(在适当的逆向引用替换完之后).提示

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

官网提示是这样的,对/e修饰符的支持已删除.请改用preg_replace_callback()原因是/e 修正符使 preg_replace() 将 replacement 参数当作 PHP 代码(在适当的逆向引用替换完之后),会被一句话后门使用 看看smarty中是也是这样用的,也是存在问题$source_content = preg_replace($search.'e', "'" . $this->_quote_replace($this->left_delimit

/i,/m,/s,/x,/A,/s,/U,/x,/j,/u 等正则修饰符用法~

i (PCRE_CASELESS) 如果设置了这个修饰符,模式中的字母会进行大小写不敏感匹配. m (PCRE_MULTILINE) 默认情况下,PCRE 认为目标字符串是由单行字符组成的(然而实际上它可能会包含多行), “行首”元字符 (^) 仅匹配字符串的开始位置, 而”行末”元字符 ($) 仅匹配字符串末尾, 或者最后的换行符(除非设置了 D 修饰符).这个行为和 perl 相同. 当这个修饰符设置之后,“行首”和“行末”就会匹配目标字符串中任意换行符之前或之后,另外, 还分别匹配目标字符

PHP正则表达式模式修饰符 /i, /is, /s, /isU等

模式修饰符 下面列出了当前可用的 PCRE 修饰符.括号中提到的名字是 PCRE 内部这些修饰符的名称. 模式修饰符中的空格,换行符会被忽略,其他字符会导致错误. i (PCRE_CASELESS) 如果设置了这个修饰符,模式中的字母会进行大小写不敏感匹配. m (PCRE_MULTILINE) 默认情况下,PCRE 认为目标字符串是由单行字符组成的(然而实际上它可能会包含多行), "行首"元字符 (^) 仅匹配字符串的开始位置, 而"行末"元字符 ($) 仅匹配字

正则表达式模式修饰符

下面列出了当前可用的 PCRE 修饰符.括号中提到的名字是 PCRE 内部这些修饰符的名称. 模式修饰符中的空格,换行符会被忽略,其他字符会导致错误. i (PCRE_CASELESS) 如果设置了这个修饰符,模式中的字母会进行大小写不敏感匹配. m (PCRE_MULTILINE) 默认情况下,PCRE 认为目标字符串是由单行字符组成的(然而实际上它可能会包含多行), "行首"元字符 (^) 仅匹配字符串的开始位置, 而"行末"元字符 ($) 仅匹配字符串末尾,

2016 2 - 23 arc中的所有权修饰符(_strong修饰符与_weak修饰符)

一 _strong修饰符 1._strong修饰符是id类型和对象类型默认的所有权修饰符.如下: id obj = [[NSObject alloc] init];//在没用明确变量所有权修饰符时,会被默认被_strong修饰符 id _strong obj = [[NSObject alloc] init];//此段代码上面的是相同的. 2. 如strong这个名字所示,_strong修饰符表示对对象的强引用.持有强引用的变量在超出其作用域时会被废弃.随着强引用的失效,引用的对象会随之失效.

[转]黑幕背后的__block修饰符

http://www.cocoachina.com/ios/20150106/10850.html 我们知道在Block使用中,Block内部能够读取外部局部变量的值.但我们需要改变这个变量的值时,我们需要给它附加上__block修饰符. __block另外一个比较多的使用场景是,为了避免某些情况下Block循环引用的问题,我们也可以给相应对象加上__block 修饰符. 为什么不使用__block就不能在Block内部修改外部的局部变量? 我们把以下代码通过 clang -rewrite-ob