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

posted @ 2019-05-28 22:10  星辰°  阅读(3967)  评论(0编辑  收藏  举报