koa2项目连接mongdb数据库

2023-11-30 21:12

本文主要是介绍koa2项目连接mongdb数据库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.数据库连接 

npm i mongoose

config/index.js中:

module.exports = {URL: "mongodb://127.0.0.1:27017/vue-admin"
}

config/db.js:注意移入文件路径问题

const mongoose = require("mongoose") 
const logger = require("../utils/log4js");
const dbConfig = require("./index");//连接数据库
mongoose.connect(dbConfig.URL);const db = mongoose.connection// db.on('open', () => {
//     logger.info("*****数据库状态为开启******")
//   })// 连接成功
db.on("connected", function () {logger.info("**********数据库连接成功***********");
})
// 连接失败
db.on("error", function (err) {logger.info("数据库连接失败,原因:" + err);
})
// 连接断开
db.on('disconnectied', function () {logger.info("数据库连接断开,原因:" + err);
})

app.js中引入db.js文件即可连接到数据库

// 引入数据库配置
require('./config/db')

2.mongoose连接使用

1.编写schema:字段名有无引号都行

const mongoose = require('mongoose');
const Schema = mongoose.Schema;const usersSchema = new Schema({// _id : 605d8f81e1ed264a867cfcc2,// 数组可以直接使用[],也可以使用Array"deptId" : [],"state" : Number,"role" : Number,"roleList" : [],"createTime" : { type: Date, default: Date.now },"lastLoginTime" : { type: Date, default: Date.now },"userId" : Number,"userName" : String,"userPwd" : String,"userEmail" : String,"job" : String,"mobile" : String,// 留一个备用的字段"remark": String});//   要把 schema 转换为一个 Model, 使用 mongoose.model(modelName, schema) 函数:
const users = mongoose.model('users', usersSchema);module.exports = users;

2.使用Model和mongoose

注意:查询语句形式;返回数据不能直接返回,需要返回res._doc否则会报错

const router = require('koa-router')()
const comm = require("../utils/common");
const logger = require("../utils/log4js");
const jwt = require("../utils/token");
const md5 = require("md5");
const User = require("../model/userSchema");router.prefix('/users')router.post('/login', async (ctx, next) => {let { userName, userPwd } = ctx.request.body;if(userName == '' || userPwd == '') return comm.error(comm.CODE.PARAM_ERROR,{},'用户名和密码不能为空' );// 查询数据库用户名是否存在,通过md5对用户密码进行md5()加密和和数据库进行查询try {// 后面是要查询的字段let loginUser = await User.findOne({ userName,  userPwd: md5(userPwd)}, 'userId userName userEmail job mobile deptId state role roleList')console.log(loginUser._doc,"loginUser");if(loginUser){//报错: TypeError: Converting circular structure to JSON,starting at object with constructor 'MongoClient'// 解决: mongoose不能直接返回loginUser,需要返回res._doc// 设置token: 使用用户名和密码设置token const data = loginUser._doc;let token = jwt.setToken({userName, userPwd});data.token = "Bearer " + tokenctx.body = comm.success(comm.CODE.SUCCESS, data, '登录成功')logger.info(userName+"登录成功");}} catch (error) {ctx.body = comm.error(comm.CODE.BUSINESS_ERROR,{}, error)logger.error(userName+"尝试登录失败:"+error);}
})module.exports = router

这篇关于koa2项目连接mongdb数据库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/438570

相关文章

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、