Windows下安装php的扩展dll
今天做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扩展。
1.下载适合PHP版本的dll
PECL扩展dll可以在https://pecl.php.net/packages.php找,这个是非“核心”扩展库,即不是XAMPP的PHP自带的扩展dll,得下载才能用。
下载前先查看PHP信息:
<?php phpinfo(); ?>
注意看Architecture以及PHP Extension Build两项(CTRL+F查)
我是在https://pecl.php.net/package/mysql_xdevapi下载的php_mysql_xdevapi.dll,按照以上两项下载以下这项。
2.解压并将dll加入php.ini中
注意看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,如果没找到说明没安装上。
相关链接
Windows安装PHP扩展教程:https://www.php.net/manual/zh/install.pecl.windows.php
Windows下php扩展下载:https://windows.php.net/downloads/pecl/releases/
php_mysql_xdevapi.dll相关信息:https://www.php.net/manual/zh/book.mysql-xdevapi.php
后记
扩展dll是安装上了,然而毫无作用,因为不知道这个扩展里边如何连接MySQL😂最后只能修改之前安装的MySQL的密码加密方式为[mysql_native_password]。
更改密码加密方式:https://blog.csdn.net/qq_36699423/article/details/81565906