一步一步搭建react应用-mongodb开启身份认证

[一步一步构建一个react应用-开篇](https://segmentfault.com/a/11...

git地址

  • 通过不认证的方式启动Mongodb

    mongod --port 3007  --config mongod.conf
  • mongo 连接实例 mongo --port 3307
  • 创建用户超级管理员
use admin
db.createUser(
  {
    user: "myAdmin",pwd: "XXXXX",roles: [ { role: "userAdminAnyDatabase",db: "admin" } ]
  }
)
  • 重启mongodb,加上访问控制
mongod --port 3007  --config mongod.conf --auth
  • 认证

连接时认证

mongo --port 3307 -u 'xxx' -p 'xxx' --authenticationDatabase "admin"

连接后认证

mongo --port 3307

use admin

db.auth('username','pwd')
  • 为其他库创建用户
use movies
db.createUser(
  {
    user: "moviesAdmin",pwd: "XXXX",roles: [ { role: "readWrite",db: "movies" },{ role: "read",db: "db2" } ]
  }
)
//添加user moviesAdmin,对movies有读写权限,对db2有读权限

db.js

const {MongoClient,ObjectId} = require('mongodb')
const f = require('util').format
const user = encodeURIComponent('moviesAdmin')
const pwd = encodeURIComponent('xxxxx')
const authMechanism = 'DEFAULT'
let db_name='Movies'
if(process.env.NODE_ENV=='test'){
    db_name='Movies_test'
}
const url = f(`mongodb://%s:%s@localhost:3307/${db_name}?authMechanism=%s`,user,pwd,authMechanism)

module.exports = {
    connect() {
        return MongoClient.connect(url).catch(e=>{
            console.log(e)
        })
    },id(id) {
        try {
            if (id) {
                return new ObjectId(id)
            } else {
                return new ObjectId()
            }
        } catch (e) {

        }
    }
}

相关文章

一、前言 在组件方面react和Vue一样的,核心思想玩的就是组件...
前言: 前段时间学习完react后,刚好就接到公司一个react项目...
前言: 最近收到组长通知我们项目组后面新开的项目准备统一技...
react 中的高阶组件主要是对于 hooks 之前的类组件来说的,如...
我们上一节了解了组件的更新机制,但是只是停留在表层上,例...
我们上一节了解了 react 的虚拟 dom 的格式,如何把虚拟 dom...