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

相关文章

Apache 高级配置实战之从连接保持到日志分析的完整指南

《Apache高级配置实战之从连接保持到日志分析的完整指南》本文带你从连接保持优化开始,一路走到访问控制和日志管理,最后用AWStats来分析网站数据,对Apache配置日志分析相关知识感兴趣的朋友... 目录Apache 高级配置实战:从连接保持到日志分析的完整指南前言 一、Apache 连接保持 - 性

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

eclipse如何运行springboot项目

《eclipse如何运行springboot项目》:本文主要介绍eclipse如何运行springboot项目问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目js录当在eclipse启动spring boot项目时出现问题解决办法1.通过cmd命令行2.在ecl

电脑蓝牙连不上怎么办? 5 招教你轻松修复Mac蓝牙连接问题的技巧

《电脑蓝牙连不上怎么办?5招教你轻松修复Mac蓝牙连接问题的技巧》蓝牙连接问题是一些Mac用户经常遇到的常见问题之一,在本文章中,我们将提供一些有用的提示和技巧,帮助您解决可能出现的蓝牙连接问... 蓝牙作为一种流行的无线技术,已经成为我们连接各种设备的重要工具。在 MAC 上,你可以根据自己的需求,轻松地

在Java中基于Geotools对PostGIS数据库的空间查询实践教程

《在Java中基于Geotools对PostGIS数据库的空间查询实践教程》本文将深入探讨这一实践,从连接配置到复杂空间查询操作,包括点查询、区域范围查询以及空间关系判断等,全方位展示如何在Java环... 目录前言一、相关技术背景介绍1、评价对象AOI2、数据处理流程二、对AOI空间范围查询实践1、空间查

Python+PyQt5实现MySQL数据库备份神器

《Python+PyQt5实现MySQL数据库备份神器》在数据库管理工作中,定期备份是确保数据安全的重要措施,本文将介绍如何使用Python+PyQt5开发一个高颜值,多功能的MySQL数据库备份工具... 目录概述功能特性核心功能矩阵特色功能界面展示主界面设计动态效果演示使用教程环境准备操作流程代码深度解

SpringBoot项目Web拦截器使用的多种方式

《SpringBoot项目Web拦截器使用的多种方式》在SpringBoot应用中,Web拦截器(Interceptor)是一种用于在请求处理的不同阶段执行自定义逻辑的机制,下面给大家介绍Sprin... 目录一、实现 HandlerInterceptor 接口1、创建HandlerInterceptor实

Maven项目打包时添加本地Jar包的操作步骤

《Maven项目打包时添加本地Jar包的操作步骤》在Maven项目开发中,我们经常会遇到需要引入本地Jar包的场景,比如使用未发布到中央仓库的第三方库或者处理版本冲突的依赖项,本文将详细介绍如何通过M... 目录一、适用场景说明​二、核心操作命令​1. 命令格式解析​2. 实战案例演示​三、项目配置步骤​1

golang实现动态路由的项目实践

《golang实现动态路由的项目实践》本文主要介绍了golang实现动态路由项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习... 目录一、动态路由1.结构体(数据库的定义)2.预加载preload3.添加关联的方法一、动态路由1