首先建议找到mongodb的配置文件mongod.conf把authorization的值改为disabled(如果是第一次配置那security一开始是被屏蔽的,开启它),关闭权限认证,如果关闭权限认证后能连接和使用数据库那便能肯定是权限认证的问题了
改前:
security:
authorization: enabled
改后:
security:
authorization: disabled
记得重启mongodb
如果确定是权限认证问题便把disabled再次改为enabled。
接下来就是一个mongodb的大坑了
英文好可以直接去看stack overflow上的回答
https://stackoverflow.com/questions/23943651/mongodb-admin-user-not-authorized
大概就是说,mongodb的用户创建要有顺序的
得先在admin数据库里创建一个root用户:
第一步:use admin
第二步:db.createUser({ user: "root", pwd: "123456", roles: [ { role: "root", db: "admin" } ]});
然后再登录这个root用户:
db.auth('root', '123456')
然后再换到你将要使用的数据库再创建一个用户:
第一步:use text
第二步:db.createUser({ user: "textuser", pwd: "123456", roles: [ { role: "root", db: "text" } ]});
然后再使用mongoose连接应该就没有问题了:
mongoose.connect('mongodb://textuser:123456@127.0.0.1:27017/text?authSource=text', {useNewUrlParser:true, useUnifiedTopology:true})
如果还是有问题,那authSource换为admin,用一开始创建的那个root用户:
mongoose.connect('mongodb://root:123456@127.0.0.1:27017/text?authSource=admin', {useNewUrlParser:true, useUnifiedTopology:true})
我使用以上操作解决了困扰了我3天的问题
版权声明:本文为qq_45963949原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。