使用Navicat连接PG时报错authentication method 10 not supported

举报
小麦苗DB宝 发表于 2022/04/20 17:46:16 2022/04/20
【摘要】 现象在使用Navicat Premium 12版本连接pg 12数据库时,报错“authentication method 10 not supported”,如下:其中,pg_hba.conf文件的内容如下:# "local" is for Unix domain socket connections onlylocal all all ...

现象

在使用Navicat Premium 12版本连接pg 12数据库时,报错“authentication method 10 not supported”,如下:

其中,pg_hba.conf文件的内容如下:

# "local" is for Unix domain socket connections only
local   all             all                                     trust
# IPv4 local connections:
host    all             all             127.0.0.1/32            trust
# IPv6 local connections:
host    all             all             ::1/128                 trust
# Allow replication connections from localhost, by a user with the
# replication privilege.
local   replication     all                                     trust
host    replication     all             127.0.0.1/32            trust
host    replication     all             ::1/128                 trust
host all all all scram-sha-256
#hostssl all all all cert

解决

在确保参数listen_addresses = '*',并且pg_hba.conf支持远程连接的条件下,执行pg_ctl reload后,还是报错。

这个主要原因是认证方式使用的是scram-sha-256md5,而客户端的Navicat的libpq.dll并不支持scram-sha-256md5

所以,解决方法是将最新的PG版本的libpq.dll文件拷贝到Navicat的安装目录中,我拷贝的是PG14版本的文件,如下:

最后,重新连接即可。

另外,也可以将pg_hba.conf文件中的支持远程连接的验证方式修改为trust或password也可以解决问题:

host all all all trust

最后,说到底是Navicat的版本太低导致的,所以,也可以升级你的Navicat软件也可以解决问题。

参考

https://stackoverflow.com/questions/64474420/postgresql-authentication-method-10-not-supported

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。