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
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
cd D:\MongoDB\Server\3.2\bin
mongod --dbpath D:\mongodb\data -auth