开发者社区> 问答> 正文

mysql扩展名已弃用,以后将删除:使用mysqli或PDO代替

当我尝试从PHP连接到MySQL服务器时,出现以下错误:

不推荐使用:不推荐使用mysql扩展,以后将删除:在第123行的/path/to/filename.php中使用mysqli或PDO代替

引用行上的代码是:

mysql_connect($server, $username, $password); 我确信这些论点是正确的,并且这种确切的代码已经工作了多年没有问题。确实,我是从PHP的一个源代码丰富的教程中获得的。

为什么会这样呢?

我该如何解决?

据我所知,它通过设置是可以抑制弃用错误error_reporting的php.ini排除E_DEPRECATED:

error_reporting = E_ALL ^ E_DEPRECATED 如果我这样做会怎样?

展开
收起
保持可爱mmm 2020-05-08 10:37:46 811 0
1 条回答
写回答
取消 提交回答
  • 为什么会这样呢?

    整个ext/mysqlPHP扩展,它提供了与前缀命名的所有功能mysql_,是在PHP V5.5.0正式弃用,并在PHP V7删除。

    它最初是在MySQL v3.20的PHP v2.0(1997年11月)中引入的,自2006年以来未添加任何新功能。加上缺少新功能,在复杂的安全漏洞中难以维护此类旧代码。

    自2011年6月起,该手册已包含警告,禁止其在新代码中使用。

    我该如何解决?

    如错误消息所示,您还可以考虑使用其他两个MySQL扩展:MySQLi和PDO_MySQL,可以使用其中任何一个代替ext/mysql。自v5.0以来,这两个版本都已成为PHP核心,因此,如果您使用的版本会引发这些弃用错误,则几乎可以肯定地立即就开始使用它们-即无需任何安装工作。

    它们之间略有不同,但与旧扩展相比,提供了许多优势,包括对事务的API支持,存储过程和准备好的语句(从而提供了克服SQL注入攻击的最佳方法)。PHP开发人员Ulf Wendel 对功能进行了详尽的比较。

    Hashphp.org提供了有关从迁移ext/mysql到PDO的出色教程。

    据我所知,它通过设置是可以抑制弃用错误error_reporting的php.ini排除E_DEPRECATED:

    error_reporting = E_ALL ^ E_DEPRECATED 如果我这样做会怎样?

    是的,可以抑制此类错误消息,并ext/mysql暂时继续使用旧的扩展名。但是,您实际上不应该这样做 -这是开发人员的最后警告,即该扩展可能不会与将来的PHP捆绑在一起(实际上,如前所述,它已从PHP v7中删除)。相反,你应该利用这个机会将应用程序迁移,现在,这是为时已晚。

    还要注意,该技术将禁止所有 E_DEPRECATED消息,而不仅仅是与ext/mysql扩展有关的消息:因此,您可能没有意识到即将对PHP进行的其他更改,这些更改会影响您的应用程序代码。当然,可以通过使用PHP的错误控制运算符(即在相关行之前添加)仅抑制出现问题的表达式上的错误,@但是这将抑制该表达式引发的所有错误,而不仅仅是错误E_DEPRECATED。来源:stack overflow

    2020-05-08 10:38:08
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
One Box: 解读事务与分析一体化数据库 HybridDB for MySQL 立即下载
One Box:解读事务与分析一体化数据库HybridDB for MySQL 立即下载
如何支撑HTAP场景-HybridDB for MySQL系统架构和技术演进 立即下载

相关镜像