MongoDB权限

MongoDB启动默认是不设置权限的,这一点和mysql,oracle有本质的区别。

当启动的时候增加参数 --auth才会启动权限,mongoDB最大的特点是面向数据库的权限,除了超级管理员,其他用户的权限都是与数据库一一对应的。

问题1:如何增加用户:

使用db.addUser('name','password')语句创建用户。

使用db.system.users.find()查找所有的用户。

MongoDB用户也分为普通用户和超级管理员用户,普通用户对应的是当前表的权限,超级管理员用户对应的权限是整个Mongodb的权限。普通用户只能在属于自己的表空间进行操作,不能创建其他数据库以及查询其他数据的数据,如果需要创建数据库只能使用超级管理员登录。

创建用户方式
a.在不设置权限的登录模式创建用户,在admin库下创建的用户是超级管理员在其他库创建的用户只有当前库的权限,没有其他库的权限。

b.登录的普通用户可以在当前库下创建用户,登录的超级用户可以在任何库下创建任何用户。

问题2:如何登录

使用db.auth('name'password')可以登录当前的数据库。

mongoDB默认连接登录的数据库是test,如果登录test库下的用户,只能查看Test库下的数据。如果登录库User下的用户,只能查看User下的数据。

当需要查看所有库的数据,以及使用show dbs这类全局的数据需要使用超级管理员,如何登录超级管理员呢?

超级管理员也有默认的数据库,这个数据库是admin,切换数据库到admin,然后使用db.auth登录超级管理员,登录好之后,就可以进入任意库CRUD以及使用show dbs操作了。

当你登录了A库,在登录B库,这个时候相当于你拥有了A库和B库两个库的权限,你可以自由的在这两个库下进行CRUD操作,如果你的数据库有A,B,C这个时候你登录了A,B,C三个数据库,你就可以在这三个数据库下自由的操作,有点类似超级管理员的操作。

在admin库下有一张users表,通过db.system.users.find();查找所有的用户,可以看到超级管理员roles是root,其他的用户role是dbowner表示只有当前数据库下的权限。

总结:mongodb的数据权限是和数据库绑定的,这个也是可以理解的因为nosql数据库无法使用join等联合查询,一个库对应自己的用户,当需要查询全局的数据时,需要使用超级管理员,超级管理员也有自己的数据库那个库就是admin,也就是说在admin库下创建的用户都是超级管理员,具体所有库的CRUD权限

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring中配置MongoDB权限,可以通过以下几个步骤实现: 1. 配置MongoDB连接属性: 在Spring的配置文件(如application.properties或application.yml)中,设置MongoDB的连接属性,包括主机名、端口号、数据库名称等。示例如下: ```properties spring.data.mongodb.host=localhost spring.data.mongodb.port=27017 spring.data.mongodb.database=mydatabase ``` 2. 配置MongoDB的认证信息: 如果MongoDB启用了认证,你需要在配置文件中提供用户名和密码。示例如下: ```properties spring.data.mongodb.authentication-database=admin spring.data.mongodb.username=myusername spring.data.mongodb.password=mypassword ``` 这里的`authentication-database`属性指定了认证所使用的数据库,通常是`admin`。 3. 配置MongoDB权限MongoDB权限配置可以通过在数据库中创建用户并为其分配角色来实现。可以使用Mongo shell或其他管理工具来执行以下操作: a. 连接到MongoDB服务器: ``` mongo --host localhost --port 27017 -u adminusername -p adminpassword --authenticationDatabase admin ``` b. 创建用户并分配角色: ``` use mydatabase db.createUser( { user: "myuser", pwd: "mypassword", roles: [ { role: "readWrite", db: "mydatabase" } ] } ) ``` 这里创建了一个名为`myuser`的用户,并为其分配了`readWrite`角色,该角色对`mydatabase`数据库具有读写权限。 4. 使用配置的权限: 在应用程序中使用MongoDB时,可以使用Spring Data MongoDB提供的功能来连接数据库,并使用在步骤3中创建的用户进行权限验证。示例代码如下: ```java @Configuration @EnableMongoRepositories(basePackages = "com.example.repository") public class MongoConfig extends AbstractMongoClientConfiguration { @Value("${spring.data.mongodb.host}") private String host; @Value("${spring.data.mongodb.port}") private int port; @Value("${spring.data.mongodb.database}") private String database; @Value("${spring.data.mongodb.username}") private String username; @Value("${spring.data.mongodb.password}") private String password; @Override protected String getDatabaseName() { return database; } @Override public MongoClient mongoClient() { MongoCredential credential = MongoCredential.createCredential(username, database, password.toCharArray()); return new MongoClient(new ServerAddress(host, port), credential, MongoClientOptions.builder().build()); } } ``` 这里的`MongoConfig`类继承了`AbstractMongoClientConfiguration`类,配置了MongoDB的连接和认证信息。通过`@EnableMongoRepositories`注解启用Spring Data MongoDB的功能,并指定了存储库的包路径。 这样,你就可以使用Spring连接到MongoDB,并在配置的权限下进行操作了。请根据实际情况修改配置文件和代码中的参数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值