• 994阅读
  • 1回复

错误Deprecated: mysql_connect(): The mysql extension is deprecated and will be removed

楼层直达
今天写PHP代码,遇到了这个非常不友好的报错(Deprecated: mysql_connect(): The mysql extension is deprecated and will be removed in the future:),很是烦人,查看了很多前辈们的博客,最终找到了这些方法,留作后用吧,万一哪天又忘记了......................... zUJPINDb  
DA/ \[w?J  
php 5个版本,5.2、5.3、5.4、5.5,怕跟不上时代,新的服务器直接上5.5,但是程序出现如下错误:Deprecated: mysql_connect(): The mysql extension is deprecated and will be removed in the future: use mysqli or PDO instead in,看意思就很明了,说mysql_connect这个模块将在未来弃用,请你使用mysqli或者PDO来替代。 \Jr7Hy1;  
C.hRL4+;Zm  
- !s=`9o  
e|.a%,Dcy  
解决方法1: Y r 1k\q  
禁止php报错 Hr=?_Un"  
Ny 7vId  
display_errors = On lC=T{rR  
改为 ROr|  <  
display_errors = Off 6i*LP(n  
鉴于这个服务器都是给用户用的,有时候他们需要报错,不能这做,让他们改程序吧 vA0f4W 8+  
 H r;\}  
下面就是我们常用的方法了: MF4B 2d  
DV jsz  
解决方法2: lgh+\pj  
常用的php语法连接mysql如下 Ip;;@o&D  
&,iPI2`O A  
复制代码 Eilo;-El  
<?php ~X1<x4P\  
$link = mysql_connect('localhost', 'username', 'password'); ]YwvwmZ  
mysql_select_db('db_name', $link); jI,?*n<  
将mysql_connect() S *K0OUq  
改成mysqi_connect() LkUi^1((e  
<?php 0*8uo W t&  
$link = @mysqli_connect('localhost', 'username', 'password', 'db_name'); e^Glgaf  
复制代码 F=~LVaF/_  
常用mysql建表SQL如下 ;&]oV`Ib  
)VFS&|#\  
<?php }i@%$Ixsn  
//  旧写法 K8|>"c~  
mysql_query('CREATE TEMPORARY TABLE `table`', $link); *aS[^iX?s  
// 新的 AWz|HF#-  
mysqli_query($link, 'CREATE TEMPORARY TABLE `table`'); P/doNv}iG  
解决方法三: qJT|om L Y  
在php程序代码里面设置报警级别 yU< "tgE  
@w@ `-1  
<?php L|K^w *\C  
error_reporting(E_ALL ^ E_DEPRECATED); E j/P:nB  
如此一来,旧可以解决掉这个可恶的错误了 qBXIR }  
只看该作者 安逸沙发  发表于: 2019-08-26
PHP在安装后,会在php.ini 文件中设置报错、提醒、警告等方式的出现,这样的方式可以使我们在调试PHP程序的时候能及时了解程序所存在的问题。然后,有时候我们并不需要提醒、警告 等内容,比如当我们使用PHP5.5(或更高)时,搭配MySql 开发环境时,使用了较老的 MySql连接方式,此时PHP 就会提示:请使用最新的 MySql 连接方式,当你在使用其读取数据库内容作为 json 格式(或其他)返回前台时,往往内容就会发生错误 <,Pl31g^  
]TJ258P}  
-?l`LbD  
@REMl~"D5  
如何屏蔽这个错误呢,方法有下: 'Fc$?$c\  
r&ys?@+G  
1,在可能(或已经)发生提醒,或错误,或警告的页面添加屏蔽错误提醒: )c?nh3D  
<Ql2+ev6  
cj^hwtx   
F(ZczwvR  
error_reporting(E_ALL ^ E_DEPRECATED); 6$kh5$[  
H: ;XU  
//在本版本php5.5,已经不建议采用老式的mysql连接方法 1|AY&u%fiP  
d(:I~m  
//但speedPHP还是沿用着老式的连接方法,这时php会报E_deprecated提示,此时关掉该提示就Ok了,也可以将 (Q&O'ng1  
h(GSM'v  
//php置于部署模式(非开发模式),但最好的解决方法是采用最新的speedPHP )/Gi-::  
)]LP8 J&  
zD<8.AIGC  
^t*Ba>A  
一般还可以使用下面的内容来解决一些 notice waring 等问题 US"UkY-\  
rZ)7(0BBs  
ini_set("display_errors", 0); RTDplv; ]  
pSEaE9AX%  
error_reporting(E_ALL ^ E_NOTICE); ;j[:tt\k  
s?&S<k-=fr  
error_reporting(E_ALL ^ E_WARNING); ZR"qrCSw`  
Z c#Jb  
fZLAZMrM  
+(z[8BJl  
2,打开php.ini文件,找到相关设置(如下图),将 on 改成 off,就可以屏蔽出错(不推荐此方法): #?eMEws  
83p8:C.Ze  
)K`tnb.Pf  
A:(qF.Tm  
p,uM)LD  
a<>cbP  
有时候修改了 php.ini 的dispaly_errors 还是不行,那就参照下面的方法: s8qpK; O  
Ke]'RfO\  
修改php.ini,将display_errors = On 改为 display_errors = Off,结果还是不行。百度了下,原来还要在php-fpm.conf里设置。 3H4T*&9;n  
Y?zo")  
打开php-fpm.conf,找到: ae2SU4Jx  
hx/A215L  
<value name="php_defines"> ~ahu{A4Bw  
"?W8 o[c+  
        </value><value name="sendmail_path">/usr/sbin/sendmail -t -i</value> [a}Idi` K  
oz[G'[\}F  
<value name="display_errors">0</value> O'.{6H;t  
xon^=Wo;  
将其中的值从1改为0就可以了。 jZvIqR/  
\yLFV9P}EL  
3,这种方法非常适用那些项目中已经决定要采用某种一定会引起 提醒 或 警告的方式,一招屏蔽,一劳永逸: IlI5xkJ(  
NqFfz9G)  
首先参照2,找到相关的 dispaly_errors 的位置,将 Off 改成 On +bb-uoZf  
f'`y-]"V5)  
紧接着找到下图这个位置,修改你需要报错的级别,或不需要报错的级别 Yfs eX;VX  
WU.eeiX  
1-.i^Hal  
%rEP.T\i  
qDfhR`1k  
kKDf%=  
参照的报错级别如下: Y;dqrA>@  
_6]CT0  
9J<vkxG9`  
cA| n*A-j<  
定义和用法: =Pp-9<& S  
error_reporting() 设置 PHP 的报错级别并返回当前级别。 mT;   
U> <$p{ )  
函数语法: $H/: -v  
error_reporting(report_level) 5B3sRF}  
}b{7+ + Ah  
如果参数 level 未指定,当前报错级别将被返回。下面几项是 level 可能的值: gnf4H V~  
值 常量 描述 5 (q4o`  
1 E_ERROR 致命的运行错误。错误无法恢复,暂停执行脚本。 VmXXj6l&  
2 E_WARNING 运行时警告(非致命性错误)。非致命的运行错误,脚本执行不会停止。 a,n#E!zT?w  
4 E_PARSE 编译时解析错误。解析错误只由分析器产生。 i|S/g.r  
8 E_NOTICE 运行时提醒(这些经常是你代码中的bug引起的,也可能是有意的行为造成的。) '=Acg"aT  
16 E_CORE_ERROR PHP启动时初始化过程中的致命错误。 PM QlJ&  
32 E_CORE_WARNING PHP启动时初始化过程中的警告(非致命性错)。 { / ,?3  
64 E_COMPILE_ERROR 编译时致命性错。这就像由Zend脚本引擎生成了一个E_ERROR。 Lg-!,Y   
128 E_COMPILE_WARNING 编译时警告(非致命性错)。这就像由Zend脚本引擎生成了一个E_WARNING警告。 Pv*]AF;9pQ  
256 E_USER_ERROR 用户自定义的错误消息。这就像由使用PHP函数trigger_error(程序员设置E_ERROR) /38XaKc{6  
512 E_USER_WARNING 用户自定义的警告消息。这就像由使用PHP函数trigger_error(程序员设定的一个E_WARNING警告) jm'^>p,9G  
1024 E_USER_NOTICE 用户自定义的提醒消息。这就像一个由使用PHP函数trigger_error(程序员一个E_NOTICE集) o Z%oP V:  
2048 E_STRICT 编码标准化警告。允许PHP建议如何修改代码以确保最佳的互操作性向前兼容性。 CWb*bw0  
4096 E_RECOVERABLE_ERROR 开捕致命错误。这就像一个E_ERROR,但可以通过用户定义的处理捕获(又见set_error_handler()) 7IrH(~Fo  
8191 E_ALL 所有的错误和警告(不包括 E_STRICT) (E_STRICT will be part of E_ALL as of PHP 6.0) D&DbxTi  
Ve xxdg  
|:L}/onK  
EQ>@K-R  
x X.{(er  
K.b :ae^k  
h&rZR`g  
例子: vX&W;&  
任意数目的以上选项都可以用“或”来连接(用 OR 或 |),这样可以报告所有需要的各级别错误。 zu 7Fq]zD  
例如,下面的代码关闭了用户自定义的错误和警告,执行了某些操作,然后恢复到原始的报错级别: ju1B._48  
vdot .  
+fQJ#?N2n  
$<3^( y  
<?php gJ^taUE  
//禁用错误报告 s&XL{FE  
error_reporting(0); F45-M[z  
e%IbM E]x  
//报告运行时错误 w: mm@8N  
error_reporting(E_ERROR | E_WARNING | E_PARSE); {]$)dz5  
as@? Kv  
//报告所有错误 ~ e a K]|  
error_reporting(E_ALL); o'8nQ Tao  
?>
快速回复

限100 字节
安逸网提示:如果您提交过一次失败了,可以用”恢复数据”来恢复帖子内容
 
认证码:
上一个 下一个