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

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

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

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

D:
cd D:MongoDBServer3.2in
mongod --dbpath D:mongodbdata

然后,修改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:MongoDBServer3.2in
mongod --dbpath D:mongodbdata -auth
 
原文地址:https://www.cnblogs.com/luludongxu/p/5850087.html