【PHP】SQLSTATE[HY000] [2054] The server requested authentication method unknown to the client


SQLSTATE[HY000] [2054] The server requested authentication method unknown to the client

搜索了下应该是 MySQL 8默认使用了新的密码验证插件:caching_sha2_password ,而有些 PHP 版本不支持这个问题造成的

解决办法:

修改登录用户的 plugin 为 mysql_native_password

mysql -uroot -p
use mysql;
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '密码';
FLUSH PRIVILEGES;

以上修改完成以后,本地链接没有问题,但是远程连接还是不行,需要修改 host 为 %

update user set host = '%' where user ='root';

假如上一步修改不成功,提示有重复数据 Duplicate entry ‘%-root’ for key ‘user.PRIMARY’,删除其他的信息

delete user where user='root' and host ='%';

以上可以解决了已建账号的密码认证问题

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值