当前位置:Gxlcms > 数据库问题 > mongodb C#连接报错 Invalid credentials for database 'admin'

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

时间:2021-07-01 10:21:17 帮助过:2人阅读

这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'

标签:

人气教程排行