我有几个数据库,不想为每个数据库创建单独的用户帐户. MongoDB支持使用另一个数据库中定义的帐户验证对数据库的访问权限的概念,但语法示例很难得到.
当我终于弄明白时,我即将发布一个问题.这是为了以防万一
解决方法
这是
mongodb,mongoose,节点设置的语法.
>从mongo shell在admin数据库中创建数据库用户
使用管理员
db.addUser({user:“mydbuser”,pwd:“mypassword”,roles:[]})
>创建数据库并添加用户 – userSource指示该用户
凭据在管理数据库中定义
使用mydb
db.addUser({user:“mydbuser”,userSource:“admin”,roles:[“readWrite”,“dbAdmin”]})
>在mongoose连接字符串中指定auth参数
var myDB = mongoose.createConnection(“mongodb:// mydbuser:mypassword @ myipaddress:27017 / mydb”,{auth:{authdb:“admin”}});
选项{auth:…}是指定必须针对admin db对用户帐户进行身份验证的选项.
>类似于从mongo shell连接到数据库
mongo myipaddr:27017 / mydb -u“mydbuser”-p“mypassword”
注意:用户“mydbuser”只对mydb具有读/写和管理访问权限.您可以找到有关用户权限here的更多信息.该方案的更完整示例是here
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。