标签:说明 class targe http sql数据库 echo window eth l数据库
今天做PHP实验需要连接MySQL数据库,我电脑上之前已经安装了MySQL服务,所以想直接用之前安装的MySQL,不用XAMPP里的MySQL了。
折腾了好长时间,总是提示
Warning: mysqli::__construct(): The server requested authentication method unknown to the client [caching_sha2_password] in F:\xampp\htdocs\Test\test.php on line 15 Warning: mysqli::__construct(): (HY000/2054): The server requested authentication method unknown to the client in F:\xampp\htdocs\Test\test.php on line 15 连接失败: The server requested authentication method unknown to the client
其实之前用Navicat连接MySQL的时候就出现过类似的问题,因为MySQL8.0密码加密方式换成了[caching_sha2_password]方式,老版本Navicat还不支持,更新了就没事了。然而不知道是我这XAMPP里的PHP版本低还是怎么回事,网上说7.x版本已经支持了[caching_sha2_password]密码加密方式,但我这就一直报错。
后来看某些PHP教程发现有个扩展dll支持[caching_sha2_password]密码加密方式:php_mysql_xdevapi.dll,然后就下载安装了php_mysql_xdevapi.dll扩展。
PECL扩展dll可以在https://pecl.php.net/packages.php找,这个是非“核心”扩展库,即不是XAMPP的PHP自带的扩展dll。
下载前先查看PHP信息:
<?php echo phpinfo(); ?>
注意看Architecture以及PHP Extension Build两项(CTRL+F直接查)
我是在https://pecl.php.net/package/mysql_xdevapi下载的php_mysql_xdevapi.dll,按照以上两项下载以下这项。
注意看Loaded Configuration File以及extension_dir两项(CTRL+F直接查)
解压后将dll文件复制到extension_dir的文件夹内。去Loaded Configuration File那打开php.ini文件,CTRL+F找extension=php_ftp.dll,在其之后加上extension=php_mysql_xdevapi.dll(貌似文件开头直接加也可以)。
重启Apache服务器,查看PHP信息,CTRL+F找mysql_xdevapi,如果没找到说明没安装上。
教程:https://www.php.net/manual/zh/install.pecl.windows.php
php_mysql_xdevapi.dll相关信息:https://www.php.net/manual/zh/book.mysql-xdevapi.php
扩展dll是安装上了,然而毫无作用,因为不知道这个扩展里边如何连接MySQL??最后只好老老实实用XAMPP自带的MySQL服务了。
其实可以修改之前安装的MySQL的密码加密方式为[mysql_native_password],但是我怕改完之前的项目什么的又出问题,所以就没试这种方法。
更改密码加密方式:https://blog.csdn.net/qq_36699423/article/details/81565906
标签:说明 class targe http sql数据库 echo window eth l数据库
原文地址:https://www.cnblogs.com/dream0-0/p/10940654.html