首先是对MongoDB用户和权限的设置,如果不设置用户的话,直接使用mongo命令就可以进入客户端shell界面进行操作了,但是如果没有设置用户的话,总感觉少了点什么,于是经过半天的查找和实践,差不多把用户和权限弄明白了。总结如下:

如果按照以下这个指令安装的话:

mongod --install --dbpath "C:\Program Files\mongodb\data\db" --logpath "C:\Program Files\mongodb\data\log\MongoDB.log"

如下:

c:\Program Files\mongodb\bin>mongod --install --dbpath "C:\Program Files\mongodb\data\db" --logpath "C:\Program Files\mongodb\data\log\MongoDB.log"

Fri Apr 05 13:47:43.164

Fri Apr 05 13:47:43.168 warning: 32-bit servers don't have journaling enabled by default. Please use --journal if you want durability.

Fri Apr 05 13:47:43.169

Fri Apr 05 13:47:43.169 Trying to install Windows service 'MongoDB'

Fri Apr 05 13:47:43.170 There is already a service named 'MongoDB', aborting

c:\Program Files\mongodb\bin>net start MongoDB

Mongo DB 服服务务已已经经启启动动成成功功。。

c:\Program Files\mongodb\bin>mongo

MongoDB shell version: 2.4.1

connecting to: test

Server has startup warnings:

Fri Apr 05 13:48:02.516 [initandlisten]

Fri Apr 05 13:48:02.516 [initandlisten] ** NOTE: This is a 32 bit MongoDB binary.

Fri Apr 05 13:48:02.516 [initandlisten] **       32 bit builds are limited to less than 2GB of data (or less with --journal).

Fri Apr 05 13:48:02.516 [initandlisten] **       Note that journaling defaults to off for 32 bit and is currently off.

Fri Apr 05 13:48:02.516 [initandlisten] **       See http://dochub.mongodb.org/core/32bit

Fri Apr 05 13:48:02.516 [initandlisten]

> show dbs

admin   (empty)

local   0.03125GB

>

可以看到有两个默认的数据库admin和local

实例1:创建一个用户名为root,密码为admin的用户,如下:

> use admin

switched to db admin

> db.addUser("root","admin")

{

        "user" : "root",

        "readOnly" : false,

        "pwd" : "bde0d84f6749c235a6b4e36d945eb666",

        "_id" : ObjectId("515e662430d89f61f6991c91")

}

> show collections

Fri Apr 05 13:50:36.685 JavaScript execution failed: error: {

        "$err" : "not authorized for query on admin.system.namespaces",

        "code" : 16550

} at src/mongo/shell/query.js:L128

>

说明:使用以上指令show collections的时候,发现报错了。是因为没有权限。做如下操作:

> db.auth("root","admin");

1

说明:返回1表示验证成功了,返回0表示验证失败。

此时,输入以下指令:show collections则可以看到admin下的集合了。

> show collections

system.indexes

system.users

> db.system.users.find()

{ "_id" : ObjectId("515e662430d89f61f6991c91"), "user" : "root", "readOnly" : false, "pwd" : "bde0d84f6749c235a6b4e36d945eb666" }

>

实例2:在用户名为root,密码为admin的用户下创建一个student数据库,并在student数据库中创建一个stu的集合并插入一个文档,如下:

> use student

switched to db student

> db.stu.insert({"name":"maoyuanjun","age":25,"sex":"male"})

> db.stu.find()

{ "_id" : ObjectId("515e676630d89f61f6991c92"), "name" : "maoyuanjun", "age" : 25, "sex" : "male" }

退出服务器,重新登陆如下:

c:\Program Files\mongodb\bin>mongo

MongoDB shell version: 2.4.1

connecting to: test

> show dbs

Fri Apr 05 13:58:05.420 JavaScript execution failed: listDatabases failed:{ "ok" : 0, "errmsg" : "unauthorized" }

at src/mongo/shell/mongo.js:L46

出错原因:是没有权限。则先判断是否有权限,如下:

> use admin

switched to db admin

> db.auth("root","admin")

1

> show dbs

admin   0.0625GB

local   0.03125GB

student 0.0625GB

>

这时,我们可以看到用户root,密码admin的用户下多了一个student数据库。

实例3:在创建一个用户

c:\Program Files\mongodb\bin>mongo

MongoDB shell version: 2.4.1

connecting to: test

> use admin

switched to db admin

直接添加用户会报错:

> db.addUser("test","123456")

Fri Apr 05 14:01:31.404 JavaScript execution failed: error: { "$err" : "not authorized for query on admin.system.users", "code" : 16550 } at src/mongo/shell/query.js:L128

做权限的判断:

> db.auth("root","admin");

1

> use admin

switched to db admin

> db.addUser("test",123456)

{

        "user" : "test",

        "readOnly" : false,

        "pwd" : "c8ef9e7ab00406e84cfa807ec082f59e",

        "_id" : ObjectId("515e68e2be252e81c5dee198")

}

> show collections

system.indexes

system.users

> db.system.users.find()

{ "_id" : ObjectId("515e662430d89f61f6991c91"), "user" : "root", "readOnly" : fa

lse, "pwd" : "bde0d84f6749c235a6b4e36d945eb666" }

{ "_id" : ObjectId("515e68e2be252e81c5dee198"), "user" : "test", "readOnly" : fa

lse, "pwd" : "c8ef9e7ab00406e84cfa807ec082f59e" }

>

MongoDB数据库用户名和密码的设置的更多相关文章

  1. MongoDB 添加用户名和密码

    MongoDB 添加用户名和密码 我用的是 mongodb3.6,如果没有的话先安装. sudo apt install mongodb 终端输入mongo,首先添加管理用户, show dbs // ...

  2. cassandra用户名和密码的设置

    设置Cassandra使用用户名和密码验证的步骤如下: 1.修改${CASSANDRA_HOME}/conf/cassandra.yaml,把authenticator: AllowAllAuthen ...

  3. 修改oralce数据库用户名和密码

    首先以sys用户登录数据库 一.修改用户名 查到到所需修改用户名称的用户需要:select user#,name from user$;(例如查到有一个normal的用户对应的user#=61) 修改 ...

  4. 修改oracle数据库用户名和密码

    第一步:连接数据库 使用ssh工具以root身份连接服务器, 然后切换到oracle用户:su - oracle(回车) 使用sqlplus连接数据库:sqlplus /nolog(回车) 以管理员身 ...

  5. DB 从zl.xml中导入数据库用户名及密码等!

    package com.dy.java; import java.io.FileInputStream; import java.io.FileNotFoundException; import ja ...

  6. window系统中 mongodb创建用户名和密码

    use admindb.createUser({user:"root",pwd:"root",roles:[{"role":"us ...

  7. mongodb设置用户名和密码

    需求:我们需要在一个mongodb上面新建两个数据库,每个数据库的用户名和密码不一样,讲道理来说我们直接设置admin,就可以控制所有的数据库,不过用起来总是感觉有各种问题,目前还不太熟悉mongod ...

  8. spring boot 配置文件加密数据库用户名/密码

    这篇文章为大家分享spring boot的配置文件properties文件里面使用经过加密的数据库用户名+密码,因为在自己做过的项目中,有这样的需求,尤其是一些大公司,或者说上市公司,是不会把这些敏感 ...

  9. 使用navicat 使用IP、用户名、密码直接连接linux服务器里面的数据库

    一般新申请的服务器,没有开通3306端口的吧,反正我遇到的,要用Navicat去连接linux下的数据库,都必须填写两个地方的信息,才能链接成功. 如果想要只通过填写ip还有数据库用户名还有密码就可以 ...

随机推荐

  1. ros::spin() 和 ros::spinOnce() 区别及详解

    版权声明:本文为博主原创文章,转载请标明出处: http://www.cnblogs.com/liu-fa/p/5925381.html 博主提示:本文基于ROS Kinetic Kame,如有更(g ...

  2. BF算法与KMP算法

    BF(Brute Force)算法是普通的模式匹配算法,BF算法的思想就是将目标串S的第一个字符与模式串T的第一个字符进行匹配,若相等,则继续比较S的第二个字符和 T的第二个字符:若不相等,则比较S的 ...

  3. ASP.NET-Web项目运行缓慢-AjaxMin在搞鬼

    AjaxMin 4.8版本是没问题,出现问题的时候是AjaxMin 5.3.xxxxx版本,起初我也不知道是AjaxMin出现问题一直以为是因为我大幅度修改Web项目架构,以及采用大量反射后所带来的后 ...

  4. 固定在网页顶部跟随滚动条滑动而滑动的DIV层

    在一个页面放2个悬浮框,悬浮框随页面的上下滚动有上下波动的效果,最终固定在同一位置 体验效果:http://hovertree.com/texiao/jsstudy/1/ 代码如下: <!DOC ...

  5. jQuery获取Select选中的Text和Value

    获取Select选中的Text和Value语法解释:$("#select_id").change(function(){//code...});   // 为Select添加事件, ...

  6. 鼠标移到导航上面 当前的LI变色 处于当前的位置

    鼠标移到导航上面 当前的LI变色 处于当前的位置,广泛应用于当前导航. 点击这里查看效果 以下是源代码: <html> <head> <meta http-equiv=& ...

  7. C# 发送Http请求 - WebClient类

    WebClient位于System.Net命名空间下,通过这个类可以方便的创建Http请求并获取返回内容. 一.用法1 - DownloadData string uri = "http:/ ...

  8. 背水一战 Windows 10 (19) - 绑定: TemplateBinding 绑定, 与 RelativeSource 绑定, 与 StaticResource 绑定

    [源码下载] 背水一战 Windows 10 (19) - 绑定: TemplateBinding 绑定, 与 RelativeSource 绑定, 与 StaticResource 绑定 作者:we ...

  9. sql 中的Bulk和C# 中的SqlBulkCopy批量插入数据 ( 回顾 and 粗谈 )

    通常,我们会对于一个文本文件数据导入到数据库中,不多说,上代码. 首先,表结构如下.   其次,在我当前D盘中有个文本文件名为2.txt的文件. 在数据库中,可以这样通过一句代码插入. Bulk in ...

  10. php中导入导出excel的原理

    在php中我们要经常导入导出excel文件,方便后台管理.那么php导入和导出excel的原理到底是什么呢?excel分为两大版本excel2007(后缀.xlsx).excel2003(后缀.xls ...