记mysql连接问题

  .net项目链接Mysql数据库时提示 Mysql Authentication to host 'xx' for user 'root' using method 'caching_sha2_password'。

  网上查找了一下资料后找到了一个不错的解决方法,作者分析了问题出现的原因也提供了几种解决方案,地址如下:https://www.cnblogs.com/HelloIwen/p/12515950.html

造成这个问题的原因是:

mysql 8.0 版本默认使用 caching_sha2_password 身份验证插件机制。

mysql 8.0以前版本(5.7)使用 mysql_native_password。

低版本升级到8.0 验证方式不变,新用户使用8.0验证方式改变,而客户端不支持新的加密方式。

随后我根据文中的方法将密码加密方式改成 mysql_native_password,但是并没有生效。

接着又尝试修改my.ini 文件 在[mysqld]下添加 default_authentication_plugin=mysql_native_password,还是没有生效。

然后又把这两个都改回了caching_sha2_password 尝试一下还是不行。

事情陷入僵局,但是在反复的尝试中发现这好像并不是密码验证的问题。如果验证方式为caching_sha2_password而密码的加密方式为mysql_native_password,那么错误提示应该是Authentication to host 'localhost' for user 'myuser' using method 'caching_sha2_password' failed with message: Access denied for user 'XXX'@'localhost' (using password: YES).

而我一开始的错误提示是Authentication to host 'localhost' for user 'myuser' using method 'caching_sha2_password' failed with message: reading from the stream has failed;额看来是一开始搜的方法就不对,根本就不是同一个错误。

最终在数据库的连接字符串后加上 SslMode=None; 问题就解决了。

还有在多次的尝试中发现一个问题就是我在本地调试项目 连服务器的数据库时在连接字符串中不加上 SslMode=None也能连接成功而同样的连接方法在服务器上的项目就会偶发性的报错,暂时还没找到原因。

 

 

 

 

posted @   风中一条狗  阅读(3615)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示