mongodb C#连接报错 Invalid credentials for database 'admin'

Posted WmW

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mongodb C#连接报错 Invalid credentials for database 'admin'相关的知识,希望对你有一定的参考价值。

这2天学习mongodb3.2.9,用户设置好了,结果用C#查询的时候报错了,看字面意思是用户验证没通过,但是我用shell是完全没有问题的,后来网上搜了下,发现原来是我用的是旧驱动,旧驱动用的是旧的校验方式,而mongodb3.2.9用的是新的SCRAM-SHA-1校验方式,所以验证就不通过了

我这边由于软件环境的问题还想继续用旧驱动,那就需要在mongodb里把校验方式给改下

首先,先关闭auth认证启动服务

D:
cd D:\MongoDB\Server\3.2\bin
mongod --dbpath D:\mongodb\data

然后,修改system.version里authSchema的currentVersion为3,默认是5(没有创建用户的话version是null,随便创建一个用户version就出现了,这个时候创建的用户的验证方式是默认的5,所以到时候是要删除的)

> use admin 
switched to db admin 
> var s= db.system.version.findOne({"_id" : "authSchema"}) 
> s.currentVersion = 3 

> db.system.version.save(s) 
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 }) 

这个时候验证方式就修改好了,然后再创建的用户的验证方式就变成3了

>use admin
>db.createUser({user:"admin",pwd:"admin",roles:[{role:"root",db:"admin"}]}) 
 
最后,以auth启动服务,就能用旧驱动验证了
D:
cd D:\MongoDB\Server\3.2\bin
mongod --dbpath D:\mongodb\data -auth
 

以上是关于mongodb C#连接报错 Invalid credentials for database 'admin'的主要内容,如果未能解决你的问题,请参考以下文章

MySQL连接报错

C# Socket使用ssl连接报错,是证书问题?还是方法问题?

在C#里连接SQL 2008 报错:已成功与服务器建立连接 但登录前握手期间发生错误 网络名不可再用

sql server 2008 R2连接报错

解决shell连接报错22端口问题

远程连接报错