MongoDB默认是不需要输入用户名和密码,客户就可以登录的。但是出于安全性的考虑,我们还是要为其设置用户名和密码。本文主要介绍的是MongoDB权限管理之用户名和密码的操作,希望能对您有所帮助。

本文我们介绍MongoDB权限管理,主要介绍的是如何设置用户名和密码。接下来我们就一一介绍。

添加用户的时候必须满足以下两个条件:

1.有相关权限的情况下(后面会说)。

2.mongod没有加--auth的情况下(如果加了,你添加权限的话 会出现下面的情况)。

> use admin    
 
switched to db admin    
 
> db.addUser('sa','sa')    
 
Fri Jul 22 14:31:13 uncaught exception: error {    
 
"$err" : "unauthorized db:admin lock type:-1 client:127.0.0.1",    
 
"code" : 10057    
 
}    
 
>    

所以我们添加用户时必须先在没有加--auth的时候添加个super  admin。

服务起来后,进入./mongo。

[root@:/usr/local/mongodb/bin]#./mongo    
 
MongoDB shell version: 1.8.2    
 
connecting to: test    
 
> use admin    
 
switched to db admin    
 
> db.adduser('sa','sa')    
 
Fri Jul 22 14:34:24 TypeError: db.adduser is not a function (shell):1    
 
> db.addUser('sa','sa')    
 
{    
 
"_id" : ObjectId("4e2914a585178da4e03a16c3"),    
 
"user" : "sa",    
 
"readOnly" : false,    
 
"pwd" : "75692b1d11c072c6c79332e248c4f699"    
 
}    
 
>    

这样就说明 已经成功建立了,然后我们试一下权限。

> show collections    
 
system.indexes    
 
system.users   

在没有加--auth的情况下 可以正常访问admin喜爱默认的两个表。

> db.system.users.find()    
 
{ "_id" : ObjectId("4e2914a585178da4e03a16c3"), "user" : "sa", "readOnly" : false, "pwd" : "75692b1d11c072c6c79332e248c4f699" }>    

已经成功建立。

下面把服务加上--auth的选项,再进入./mongo。

MongoDB shell version: 1.8.2    
 
connecting to: test    
 
> use admin    
 
switched to db admin    
 
> show collections    
 
Fri Jul 22 14:38:49 uncaught exception: error: {    
 
"$err" : "unauthorized db:admin lock type:-1 client:127.0.0.1",    
 
"code" : 10057    
 
}    
 
>    

可以看出已经没有访问权限了。

我们就用自己的密钥登录下:

> db.auth('sa','sa')    
 
1   

返回1说明验证成功!

再show collections下就成功了。

.....

我们登录其它表试试:

[root@:/usr/local/mongodb/bin]#./mongo    
 
MongoDB shell version: 1.8.2    
 
connecting to: test    
 
> use test    
 
switched to db test    
 
> show collections    
 
Fri Jul 22 14:40:47 uncaught exception: error: {    
 
"$err" : "unauthorized db:test lock type:-1 client:127.0.0.1",    
 
"code" : 10057    
 
}   

也需要验证,试试super admin登录:

[root@:/usr/local/mongodb/bin]#./mongo    
 
MongoDB shell version: 1.8.2    
 
connecting to: test    
 
> use test    
 
switched to db test    
 
> show collections    
 
Fri Jul 22 14:40:47 uncaught exception: error: {    
 
"$err" : "unauthorized db:test lock type:-1 client:127.0.0.1",    
 
"code" : 10057    
 
}    
 
> db.auth('sa','sa')    
 
0   

返回0验证失败。

好吧,不绕圈子,其实super admin必须从admin那么登录 然后 再use其它表才可以。

> use admin    
 
> use admin  
 
switched to db admin    
 
> db.auth('sa','sa')    
 
1    
 
> use test    
 
switched to db test    
 
> show collections    
 
>    

如果想单独访问一个表,用独立的用户名,就需要在那个表里面建相应的user。

[root@:/usr/local/mongodb/bin]#./mongo    
 
MongoDB shell version: 1.8.2    
 
connecting to: test    
 
> use admin    
 
switched to db admin    
 
> db.auth('sa','sa')    
 
1    
 
> use test    
 
switched to db test    
 
> db.addUser('test','test')    
 
{    
 
"user" : "test",    
 
"readOnly" : false,    
 
"pwd" : "a6de521abefc2fed4f5876855a3484f5"    
 
}    
 
>    

当然必须有相关权限才可以建立。

再登录看看:

[root@:/usr/local/mongodb/bin]#./mongo    
 
MongoDB shell version: 1.8.2    
 
connecting to: test    
 
> show collections    
 
Fri Jul 22 14:45:08 uncaught exception: error: {    
 
"$err" : "unauthorized db:test lock type:-1 client:127.0.0.1",    
 
"code" : 10057    
 
}    
 
> db.auth('test','test')    
 
1    
 
> show collections    
 
system.indexes    
 
system.users    
 
>

MongoDB权限管理之用户名和密码的操作的更多相关文章

  1. MongoDB——权限管理

    MongoDB--权限管理 MongoDB默认是没有权限验证的,但生产环境中,没有权限控制是很不安全的. 我们先不详谈太多概念,直接动手创建两个典型的账号: 超级管理员,类似sql server的sa ...

  2. mongodb权限管理

    说到mongodb就得先谈谈mongodb的用户组,和传统的关系型数据库不一样,mongodb并没有在创建应用时就要求创建权限管理组,所以类似于Robomongo这样的数据库可视化工具在创建conne ...

  3. Windows下MongoDB安装及创建用户名和密码

    下载MongoDB的安装文件https://www.mongodb.com/download-center#community,选择合适的版本(注:本人选择的是3.2.6) 下载完MongoDB.ms ...

  4. mongodb权限管理(转)

    Mongodb 预定义角色 Mongodb 中预定义了一些角色,把这些角色赋予给适当的用户上,用户就只能进行角色范围内的操作. 数据库用户角色 (所有数据库都有) read 用户可以读取当前数据库的数 ...

  5. 基于MongoDB权限管理+gridfs文件上传------云盘系统

    学了一会Mongo,开始毕设的编写. 毕设目前一共分为如下模块 用户管理模块 管理员管理模块 文件管理模块 分享模块 目前已经完成了权限管理部分的后端代码.上传下载已经实现Demo.先把权限弄好后在整 ...

  6. Web端权限管理新增实用功能:批量增加操作,简单方便快速!

    扩展了吉日嘎拉的Web端权限管理功能后,每次添加菜单倒没啥问题,毕竟菜单的数量有限,可是每增加一个模块.功能或者说权限控制点,就得针对各种常规操作,新增很多遍. 浪费时间,还容易出错.新增了一个字典表 ...

  7. MongoDB 权限管理 用户名和密码的操作

    在刚安装完毕的时候MongoDB都默认有一个admin数据库,而admin.system.users中将会保存比在其它数据库中设置的用户权限更大的用户信息.  当admin.system.users中 ...

  8. Mongodb 权限管理

  9. .NET快速信息化系统开发框架 V3.2 -> WinForm“组织机构管理”界面组织机构权限管理采用新的界面,操作权限按模块进行展示

    对于某些大型的企业.信息系统,涉及的组织机构较多,模块多.操作权限也多,对用户或角色一一设置模块.操作权限等比较繁琐.我们可以直接对某一组织机构进行权限的设置,这样设置后,同一组织机构的用户就可以拥有 ...

随机推荐

  1. YII2.0上传文件

    针对于YII2.0官方手册来说,我稍微修改了一些内容具体的就是把model层里定义的uoload方法在controller方法里合并了 创建模型 namespace app\models; use y ...

  2. iOS APP上线流程

    前言:作为一名IOS开发者,把开发出来的App上传到App Store是必须的.下面就来详细介绍下具体流程. 1.打开苹果开发者中心:https://developer.apple.com 打开后点击 ...

  3. # 20145210 《Java程序设计》第03周学习总结

    教材学习内容总结 第四章 类与对象 在定义类这个小结里,有很多新的术语,书上的比喻很形象,对于理解这部分的内容有很大帮助,现总结如下: •类与对象的关系:要产生对象必须先定义类,类是对象的设计图,对象 ...

  4. 清除浮动4-插入多余的div

    <!doctype html><html> <head> <meta charset="UTF-8"> <meta name= ...

  5. Difference Between Performance Testing, Load Testing and Stress Testing

    http://www.softwaretestinghelp.com/what-is-performance-testing-load-testing-stress-testing/ Differen ...

  6. Context启动startActivity注意

    intent.setFlags()方法中参数的用例: 很多人使用startActivity时候,会碰到如下的异常:Caused by: android.util.AndroidRuntimeExcep ...

  7. js 小数取整的函数

    1.丢弃小数部分,保留整数部分 js:parseInt(7/2) 2.向上取整,有小数就整数部分加1 js: Math.ceil(7/2) 3,四舍五入. js: Math.round(7/2) 4, ...

  8. 使用isInEditMode解决可视化编辑器无法识别自定义控件的问题

    如果在自定义控件的构造函数或者其他绘制相关地方使用系统依赖的代码, 会导致可视化编辑器无法报错并提示:Use View.isInEditMode() in your custom views to s ...

  9. arraylist 转json

    java.lang.ClassNotFoundException: org.apache.commons.lang.exception.NestableRuntimeException 标签: cla ...

  10. leetcode 150. Evaluate Reverse Polish Notation ------ java

    Evaluate the value of an arithmetic expression in Reverse Polish Notation. Valid operators are +, -, ...