mongodb给不同的库设置不同的密码进行连接

默认的数据库安装之后是没有密码的,是可以直接访问的,但是如果端口不小心暴露出去了,就会存在很大的安全隐患。本节课教大家如何给mongodb设置账号密码进行访问。

设置管理员并密码登录

查看服务

默认安装好的mongodb会自动创建好服务,如下图:我们只需找到该服务就能看到启动文件在哪里,配置文件在那了。

启动文件

我们先找到当前数据库的启动文件

打开命令

上图箭头处输入cmd即可打开命令

创建管理员账号

输入如下命令

注意:一定是bin目录下输入,

输入mongo则会自动调用bin目录下的mongo.exe文件打开数据库

use admin则表示我需要使用admin这个表,也就是超级管理员的表

db.createUser 则是创建管理员账号

复制代码
mongo
use admin
db.createUser(
  {
    user: "自己的账号",
    pwd: "自己的密码",
    roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
  }
)

查看管理员账号

如果你不清楚你是否已经添加进来了,可以继续输入一下命令来查看管理员账号。

db.getUsers()

修改配置文件

好,有了账号密码之后,我们就需要修改配置文件了。在第一张图中--config 后面的路径就是配置文件路径。打开该文件,然后再加上如下代码,这样数据库的访问就需要密码校验了。

security:

authorization: enabled

重启服务

找到电脑的这个服务,然后重启就可以了。

连接测试

最后用mongocompass工具或其他数据库工具连接测试即可,连接代码如下

复制代码
mongodb://账号:密码@localhost:27017/?authSource=admin

设置其他库的密码

当然这只是针对管理员的账号设置,但我们做项目的时候会创建很多的库,比如做一个图书管理系统就有一个书籍管理的库book库,电商项目就有电商的库等等。不同的项目,创建不同的库。我们不可能直接用管理员账号去连接这些库,否则一旦账号泄漏,其他的库也会跟着遭殃。所以我们还需要对不同的库,用不同的账号密码。

在宝塔中设置库密码很简单,可视化的。接下来我将教大家如何用命令来设置密码。

管理员登录

由于设置了账号密码,所以不能直接输入mongo命令即可登录了。这里需要用管理员账号来登录。

继续在这个bin目录下,用cmd命令输入一下代码

复制代码
mongo -u 自己的账号 -p 自己的密码 --authenticationDatabase admin

选择自己的库

比如书籍管理book

use book

创建该库的管理员账号

代码如下。代码其实与上面的差不多,但是db这块要注意,db就是指你创建的库,而不是admin的库。

复制代码
db.createUser({
  user: "新库的账号",
  pwd: "新库的密码",
  roles: [{ role: "readWrite", db: "book" }]
})

连接库

最后是用代码连接数据库,如下:

注意:这里一定要注意,authSource是指你当前的库名称,不是admin,不是admin,不是admin

复制代码
mongodb://账号:密码@localhost:27017/?authSource=book
相关推荐
倔强的石头_5 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou641 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
AI全栈实验室3 天前
MongoDB迁移金仓踩了5个坑,最后一个差点回滚
mongodb
随逸1773 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再4 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip