MongoDB 权限 验证

在MongoDB中,服务启动默认是没有权限验证的,就安全性方面来说,这肯定是不行的,所以需要加上权限验证。

既然是要进行权限验证,那肯定是得有用户的吧,所以权限验证的第一步就是给MongoDB库添加用户。

启动MongoDB服务端,然后启动MongoDB客户端,在客户端使用命令给MongoDB库添加用户,看代码:

[sql] view plaincopy

  1. > db.addUser("sa","123");
  2. {
  3. "user" : "sa",
  4. "readOnly" : false,
  5. "pwd" : "f7559cfe0bc0a305f82c0d83664538fd"
  6. }

小知识:在admin库里面添加用户是全局的,也就是说在admin中添加用户,在其他库里面也是适用的。

要给MongoDB的服务器端添加权限验证,需要在启动MongoDB的服务的时候添加--auth参数,代码如下:

[sql] view plaincopy

  1. d:\mongodb\bin>mongod --dbpath d:\mongodb\data --logpath d:\mongodb\log\mongodb.log --logappend --serviceName MongoDB --auth --install
  2. all output going to: d:\mongodb\log\mongodb.log
  3. Creating service MongoDB.
  4. Service creation successful.
  5. Service can be started from the command line via ‘net start "MongoDB"‘.
  6. d:\mongodb\bin>net start "MongoDB"
  7. Mongo DB 服务正在启动 .
  8. Mongo DB 服务已经启动成功。

在这里我是以服务的方式启动MongoDB服务,第一条命令是安装服务,第二条就是启动服务了。

服务都已经启动了,那就剩下打开客户端了,这个就简单了,看代码:

[sql] view plaincopy

  1. d:\mongodb\bin>mongo
  2. MongoDB shell version: 1.8.2
  3. connecting to: test
  4. > show dbs;
  5. Mon Oct 24 21:54:13 uncaught exception: listDatabases failed:{
  6. "assertion" : "unauthorized db:admin lock type:-1 client:127.0.0.1",
  7. "assertionCode" : 10057,
  8. "errmsg" : "db assertion failure",
  9. "ok" : 0
  10. }

看到了吧,show dbs命令报异常了,再看异常的具体信息,unauthorized db:admin lock,权限验证不通过啊!

那好,下面就进行权限验证,这里唠叨一下,在进行权限验证的时候,先退出客户端,或者另起一个客户端,代码如下:

[sql] view plaincopy

  1. d:\mongodb\bin>mongo admin -u sa -p 123
  2. MongoDB shell version: 1.8.2
  3. connecting to: admin
  4. > show dbs;
  5. admin   0.078125GB
  6. local   (empty)
  7. test    (empty)

命令格式:mongo [数据库名] -u [用户名] -p [密码]

上面的show dbs可以执行并看到结果了。

到此,权限验证的过程就算完成了。

时间: 2024-08-29 00:37:05

MongoDB 权限 验证的相关文章

Spring boot连接3.03以上的mongodb 权限验证问题

由于3.0.3,mongodb加入了SCRAM-SHA-1校验方式,需要第三方工具配合进行验证,所有Spring boot连接MongoDB时会出现用户认证失败. 解决方法: > use admin switched to db admin > var schema = db.system.version.findOne({"_id" : "authSchema"}) > schema.currentVersion = 3 3 > db.sy

MongoDB 权限控制

MongoDB 版本为4.0.1 1.核心思想为: 在admin库中创建一个管理员权限用户, 然后通过这个管理员权限用户给其它库分配操作库数据的用户. 2.步骤以及注意事项如下: ①启动MongoDB服务端 ./mongod & 注意:这里后面有个d,并使用&后台运行 ②启动MongoDB客户端进行连接 ./mongo 注意:这里后面没有d ③进入admin表并创建一个管理员用户 注意:刚安装完MongoDB不带任何参数启动,是没有任何用户以及没有启动权限验证机制的. use admin

PHP.48-TP框架商城应用实例-后台23-权限管理-权限验证

权限验证 1.登录控制器 2.通过tp验证码类生成验证码图片 3.在管理员模型增加登录验证规则 4.后台中所有的控制器必须先登录才能访问 思路:在访问任何一个控制器之前都判断一个session即可,=>增加一个父控制器验证Session 让所有后台的控制器[除了Login控制器之外的]都继承自这个控制器 5.在管理员访问后台的任何一个页面之前先到数据库中查看当前管理员所在的角色是否有权限访问这个页面 在权限模型中增加此检查方法,在父类登录控制器中调用 6.后台左侧只显示当前管理员有权限访问的按钮

mongodb权限机制以及扩展

mongodb权限机制 启动权限机制之前要先在MONGODB中添加管理员账号: 1. 创建账号 重装安装一个mongodb,安装时添加一个 --auth参数: 先把安装好的从服务中删除掉(删除之后数据还在并没有删除数据) 重新安装mognodb,安装时添加上--auth参数: 现在就开启了权限机制. 现在不登录就不能操作数据库: 必须要先登录才行: 如何使用PHP操作mongodb php 操作mongodb的代码基本和命令行差不多. 要执行这个代码有个前提:PHP服务器上安装了MONGO扩展.

【3】.net MVC 使用IPrincipal进行Form登录即权限验证

1.在MVC项目中添加用户类,可以根据实际项目需求添加必要属性 public class UserData { /// <summary> /// ID /// </summary> public int UserId { get; set; } /// <summary> /// 用户名 /// </summary> public string UserName { get; set; } /// <summary> /// 角色ID列表 //

App登陆java后台处理和用户权限验证

最近做一个app项目,后台我独自一人开发,开发任务顺序安排上没有把登陆,注册和权限验证这些基本功能放在第一阶段开发,现在是部分业务相关功能已经完成,但是用户入口竟然还没有,只能说明当初需求分析的时候还是太过于着急了,把最基本的用户入口给放到后面了. 现在就需要在现有代码的基础上添加用户登录和权限验证功能. 关于登录和权限验证方面,参照以前做iOS的开发经验,App端提供用户名和密码换取token,每次通过换取的token请求需要登陆权限的操作. 现在反过来,我就需要考虑下面几个问题: 1.在现有

SpringMVC+Apache Shiro+JPA(hibernate)案例教学(二)基于SpringMVC+Shiro的用户登录权限验证

序: 在上一篇中,咱们已经对于项目已经做了基本的配置,这一篇文章开始学习Shiro如何对登录进行验证. 教学: 一.Shiro配置的简要说明. 有心人可能注意到了,在上一章的applicationContext.xml配置文件中,包含以下配置. <!-- 項目自定义的Realm --> <bean id="shiroDbRealm" class="org.shiro.demo.service.realm.ShiroDbRealm" ><

Web用户的身份验证及WebApi权限验证流程的设计和实现

前言:Web 用户的身份验证,及页面操作权限验证是B/S系统的基础功能,一个功能复杂的业务应用系统,通过角色授权来控制用户访问,本文通过Form认证,Mvc的Controller基类及Action的权限验证来实现Web系统登录,Mvc前端权限校验以及WebApi服务端的访问校验功能. 1. Web Form认证介绍 Web应用的访问方式因为是基于浏览器的Http地址请求,所以需要验证用户身份的合法性.目前常见的方式是Form认证,其处理逻辑描述如下:1. 用户首先要在登录页面输入用户名和密码,然

微信开发配置JSSDK,注入权限验证,以及invalid signature签名错误解决

在微信开发中很多功能都要用到微信JSSDK,关于JSSDK的使用,微信官方的文档已经比较详细,一定要仔细去看文档. <script src="https://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script> 我们先进入微信SDK的JS文件.在页面中使用ajax注入权限验证,关于后台的验证以及签名算法,官方文档写的很详细,也有demo可以查看. $(function(){ //var url = window.lo