1. 参考如下的文档:

    https://docs.mongodb.org/manual/tutorial/enable-authentication/

           1.1. 在启用匿名验证的情况下,创建一个可以管理所有数据库用户的用户。

use admin

db.createUser(

{

user: "admin",

pwd: "admin",

roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]

}

)

1.2. 用—auth选项重新启动MongoDB服务。

>先停止和删除已有的MongoDB服务,然后用如下的命令重新安装:

"C:\Program Files\MongoDB\Server\3.0\bin\mongod.exe" --config "C:\Program Files\MongoDB\Server\3.0\etc\mongodb.conf" --dbpath "C:\Program Files\MongoDB\Server\3.0\bin\data\db" --directoryperdb --service --install --auth

(如果去掉—auth, 就是允许匿名验证)

然后net start MongoDB.

>用命令行连接Mongo,

mongo admin -u root -p root

注意,一定要带上数据库名字admin,否则会报验证失败错误。因为它会找所在数据库中的system.users表,如果不写admin数据库的名字,可能就去找test.system.users, 当然找不到,就会报验证失败的错误。

1.3. 用命令行连接上后,就可以创建其他用户了。

当在admin中创建如下权限的用户时,是对所有数据库都有效的,也就是说权限会应用到cluster中所有的数据库中。

  • dbOwner role, when scoped to the admin database
  • userAdmin role, when scoped to the admin database
  • userAdminAnyDatabase role

例子:

db.createUser(

{

user: "dbOwner",

pwd: "dbOwner",

roles: [ { role: "dbOwner", db: "admin" } ]

}

)

目前我看到最大的权限时root:

root

Provides access to the operations and all the resources of the readWriteAnyDatabase, dbAdminAnyDatabase, userAdminAnyDatabase, clusterAdmin roles, restore combined.

Changed in version 3.0.7: The root has validate action on system. collections. Previously, root does not include any access to collections that begin with the system. prefix.

The root role includes privileges from the restore role.

例子:

db.createUser(

{

user: "root",

pwd: "root",

roles: [ { role: "root", db: "admin" } ]

}

)

另外还有readAnyDatabase,readWriteAnyDatabase。

更多的Mongo内置角色请看这个文章:https://docs.mongodb.org/manual/reference/built-in-roles/#userAdminAnyDatabase

上面的这些角色我试了几个,以下是体会:

userAdminAnyDatabase: 只能管理用户,不能查看collection中的数据,其他权限应该也没有。

dbAdminAnyDatabase: 只能查看db列表,可能能够增加和删除db,但是不能查看collection,其他很多权限应该也没有。

readWriteAnyDatabase: 可以对所有数据库的所有collection进行增删改查操作。

Root: 目前我所看到的最高角色,在 MongoVue中貌似可以做任何事情。

                                  但是: 以上的这些超级用户权限,在MongoVue中跟文档上描述的权限时一致的,但我用.net的API操作的时候,写入collection的时候总是会报验证失败的错误。

if (!String.IsNullOrWhiteSpace(userName))

{

var db1Credential = MongoCredential.CreateMongoCRCredential(databaseName, userName, password);

settings.Credentials = new[] { db1Credential };

}

在用.net的API操作Mongo的时候,要想写入一个db中的一个collection, 只有对单个的数据库创建的用户才是好用的。

db.createUser(

{

user: "user1",

pwd: "user1",

roles: [ { role: "dbOwner", db: "Database1" } ]

}

             如果要执行dropDatabase和createDatabase的操作,除了在单个的数据库上,还需要在admin也添加dbOwner的权限(或者其他创建数据库的权限?这个没试过。dbOwner是好用的。)

            

use admin

db.createUser(

{

user: "user1",

pwd: "user1",

roles: [ { role: "dbOwner", db: "admin" } ]

}

  

2. Mongo的验证机制:

参考这个文档:https://docs.mongodb.org/manual/core/authentication/

在Mongo3.0之前,默认的验证机制是MONGODB-CR, 从3.0开始,默认的验证机制是SCRAM-SHA-1.

貌似.net针对Mongo的API还不支持SCRAM-SHA-1,所以如果用Mongo3.0以及以后的版本,必须将Mongo的默认验证机制改成MONGODB-CR。 方法参考这个文章:http://stackoverflow.com/questions/30854155/how-to-change-default-authentication-method-from-scram-sha-1-back-to-mongodb-cr

就是在mongo的命令行中定位到admin数据库后,执行如下的命令:

var schema = db.system.version.findOne({"_id" : "authSchema"})

schema.currentVersion = 3

db.system.version.save(schema)

 如果要改回SCRAM-SHA-1,用如下的命令:

(参考: https://docs.mongodb.org/manual/release-notes/3.0-scram/ )

db.adminCommand({authSchemaUpgrade: 1});

此时schema.currentVersion为5.

3. 删除用户:

定位到所在的数据库后,运行命令db.dropUser('<username>')

Mongo的安全验证的更多相关文章

  1. mongo的身份验证和授权

    问题来源 刚装好的mongo,准备登陆进去测一把的,结果就给我报这个错,鄙人是新手,还不太清楚这个,现学一下~ Mongo的身份验证 在上一篇安装mongo的博客中(https://www.cnblo ...

  2. mongo 记得开启验证 auth = true

    dbpath=/mnt/mongodb/data/logpath=/usr/local/mongodb/log/mongodb.logauth = trueport=27017logappend=1f ...

  3. Docker Mongo数据库开启用户认证

    一.启动mongo容器的几种方式 #简化版 docker run --name mongo1 -p 21117:27017 -d mongo --noprealloc --smallfiles #自定 ...

  4. mongo创建数据库和用户

    1.linux安装mongo conf文件配置: 配置文件: dbpath=/home/data/mongodb/mongodb logpath=/home/data/logs/mongodb.log ...

  5. MongoDB用户验证和权限管理

    官方参考页面: https://docs.mongodb.com/v3.6/tutorial/enable-authentication/ https://docs.mongodb.com/v3.6/ ...

  6. [Config]Zabbix的Mongodb插件安装,centos

    1.yum install php-devel php-pear httpd-devel 2.安装mongo php驱动,pecl install mongo 3.pecl install mongo ...

  7. mongodb维护常用命令

    一,用户操作:1. #进入数据库adminuse admin2. #增加或修改用户密码db.addUser('name','pwd')3. #查看用户列表db.system.users.find()4 ...

  8. 32位linux(centos)下mongoDB的安装

    下载mongoDB wget http://downloads.mongodb.org/linux/mongodb-linux-i686-2.4.9.tgz 如果上面地址不对可以去官网自己下载http ...

  9. mongodb与spring mvc 整合

    1.pom文件添加对mongodb的倚赖 <dependency> <groupId>org.mongodb</groupId> <artifactId> ...

随机推荐

  1. 【CF 585E】 E. Present for Vitalik the Philatelist

    E. Present for Vitalik the Philatelist time limit per test 5 seconds memory limit per test 256 megab ...

  2. Python进阶篇:Python简单爬虫

    目录 前言 要解决的问题 设计方案 代码说明 小结 前言 前一段一直在打基础,已经学习了变量,流程控制,循环,函数这几块的知识点,就想通过写写小程序来实践一下,来加深知识点的记忆和理解.首先考虑的就是 ...

  3. BZOJ 2118 墨墨的等式(最短路)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2118 [题目大意] 求a1x1+a2y2+…+anxn=B在B的取值范围,有多少B可以 ...

  4. 【漏洞预警】Intel爆CPU设计问题,导致win和Linux内核重设计(附测试poc)

    目前研究人员正抓紧检查 Linux 内核的安全问题,与此同时,微软也预计将在本月补丁日公开介绍 Windows 操作系统的相关变更. 而 Linux 和 Windows 系统的这些更新势必会对 Int ...

  5. ASP.NET 构建高性能网站 第4篇

    部署优化 我们都知道,不同的部署方式对站点的性能是有影响的,可能有些朋友已经知道了这点,不管怎样,我们这里还是详细系统的讲述一下这个问题,熟悉的朋友权当回顾J. Release方式编译项目 如果我们的 ...

  6. 体感设备:因特尔 Intel RealSense R200,乐视LeTV Pro Xtion和Orb奥比中光bec Astra比较

    最近调试三个个厂家的体感设备,第一个是Intel的RealSense R200(参数规格:分辨率:1080p,深度有效距离:0.51-4,USB3.0),第二个是乐视LeTV Pro Xtion(参数 ...

  7. JS实现背景透明度可变,文字不透明的效果

    最近项目里需要实现这么个功能,类似网游中的聊天框,背景都是透明的,但是文字是不透明.所以如果简单的使用opacity(非IE)和alpha滤镜(IE)是无法实现这个效果的,会造成全部透明. 解决办法如 ...

  8. js面向对象写页面

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. oracle备份恢复学习

    备份和恢复是常遇到的操作,逻辑备份和物理备份.物理备份又分为冷备份和热备份. 一.逻辑备份,恢复 是指使用exp命令,简单易行,不影响正常的数据库操作.exp   用户名/密码   file=/hom ...

  10. chrome --headless --disable-gpu --dump-dom http://www.python.org

    Driving Headless Chrome with Python:Python chrome --headless --disable-gpu --dump-dom http://www.pyt ...