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 代码

那么 应该怎么办呢

事实上 仅仅要 把 preg_replace 里面 有 /e 修饰符的代码 改动成  preg_replace _callback  然后又一次写下就好了

样例

最简单的 写法

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

改动成

preg_replace("/([A-Z])/",‘gwyy‘, $str);
function gwyy($match) {
	return  ‘_‘.strtolower($match[1]);
}

第二个參数是个 函数名  然后在外部写一个函数   可是 我们每次定义一个函数 感觉非常麻烦  所以我们能够用匿名函数

比方说

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

改动成

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

就可以

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

假设在类里面 还能这么写

class a {

	private $joinStr = "__AAAAA__";

	public function __construct() {
		$this->joinStr = preg_replace_callback("/__([A-Z_-]+)__/sU",array($this,‘gwyy‘),$this->joinStr);
		echo  $this->joinStr;
	}

	public	function  gwyy($match) {
		print_r($match);
		return ‘aaa‘;
	}

}
$a = new a();

第二个參数不是一个函数 而变成了一个数组 表示 调用 $this 类 里面的 gwyy 方法 运行  gwyy会自己主动接受到 一个 $match 參数表

以下再看一个略微复杂点的样例

$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);

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

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

时间: 2024-12-30 23:22:26

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

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_

关于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  然后重新写

.NET4.5新特性async和await修饰符实现异步编程

开篇 每一个版本的.net都会引入一些新的特性,这些特性方便开发人员能够快速实现一些功能.虽然.net版本一直在更新,但是新版本对旧版本的程序都是兼容的,在这一点上微软做的还是非常好的.每次学一个新内容,第一次接触的方法在脑海里占的位置还是比较重要的,从刚开始接触.net的多线程编程是使用Thread类,然后后面写的程序只要用到异步或者多线程就马上会想到用Thread,虽然知道委托的异步调用也能够实现,但是脑海里面的排在前面还是Thread类,在那个时候不知道他们之间的区别和优劣,也就不懂得如何

[.net 面向对象编程基础] (7) 基础中的基础——修饰符

[.net 面向对象编程基础] (7) 基础中的基础——修饰符 在进入C#面向对象核心之前,我们需要先对修饰符有所了解,其实我们在前面说到变量和常量的时候,已经使用了修饰符,并且说明了变量和常量的修改符. 首先 修饰符是什么? 修饰符用于限定类型以及类型成员的申明 从定义可以看出按功能分为两类:访问修饰符和声明修饰符 1.访问修饰符 (5个) 访问修饰符 说明 public 公有访问.不受任何限制. private 私有访问.只限于本类成员访问,子类,实例都不能访问. protected 保护访

C# 中4个访问符和8个修饰符详解

4个访问修饰符(是添加到类.结构或成员声明的关键字) Public:公有的,是类型和类型成员的访问修饰符.对其访问没有限制. Internal:内部的,是类型和类型成员的访问修饰符.同一个程序集中的所有类都可以访问 Private:私有的,是一个成员访问修饰符.只有在声明它们的类和结构中才可以访问. Protected::受保护的,是一个成员访问修饰符.只能在它的类和它的派生类中访问. protected internal:访问级别为 internal 或 protected.即,“同一个程序集

Python中@修饰符的作用。

'@'符号用作函数修饰符是python2.4新增加的功能,修饰符必须出现在函数定义前一行,不允许和函数定义在同一行.也就是说@A def f(): 是非法的. 只可以在模块或类定义层内对函数进行修饰,不允许修修饰一个类.一个修饰符就是一个函数,它将被修饰的函数做为参数,并返回修饰后的同名函数或其它可调用的东西. 例如: def test02(a): print'test02' @test02 def test(a,b): print 'test' print a+b 结果: 在Python官方文

慎用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 代码(在适当的逆向引用替换完之后).提示

Xcode 7新特性Lightweight Generics 轻量级泛型与__kindof修饰符

Lightweight Generics 轻量级泛型,轻量是因为这是个纯编译器的语法支持(llvm 7.0),和 Nullability 一样,没有借助任何 objc runtime 的升级,也就是说,这个新语法在 Xcode 7 上可以使用且完全向下兼容(更低的 iOS 版本) 带泛型的容器 1 2 NSArray<NSString *> *strings = @[@"sun", @"yuan"]; NSDictionary<NSString *

新标准中set的迭代器it有const修饰符,如何去掉

新的C++11标准中,set的迭代器it有const修饰符,那么对它元素的修改就必然不能成功了.但是有时候遇到要修改stl set元素的问题,这个问题一般的解决方法是先erase这个元素,然后再insert.如果利用const_cast(*it)把it映射成一个引用的对象,那么就可以对它进行修改了.const_cast<node*>(&(*it))->b = 10;