【无标题】nodejs+mogoodb数据库写注册接口

描述

本篇文章主要记录使用nodejs + express搭建服务器,并链接mogoodb数据来书写简单的后台接口;前端项目使用的vue2的一个酒店管理项目。阅读本文章,可以了解如何连接mogoodb数据库,和一些对数据库进行操作的命令。前端如何进行跨域请求,在请求后端接口时的一些注意点。

后台项目介绍

在这里插入图片描述
这里主要介绍mogoodb数据库的连接与操作命令,对于项目其他文件就不在赘述,主要讲解有关连接mogoodb数据所涉及到的文件。
1、打开cmd,输入mongod启动数据库(请不要关掉黑窗口)
1、重新打开一个新的cmd,输入mongo(请不要关闭黑窗口)

bin/www

这里主要是搭建服务器。在本地启动该服务器,监听的端口是4000。

var app = require('../app');
var debug = require('debug')('mgserver:server');
var http = require('http');/*** normalizePort()规范化端口,一般端口号可以从环境中获取,或者默认3000*/
var port = normalizePort(process.env.PORT || '4000');
app.set('port', port);/*** 创建http服务*/
var server = http.createServer(app);/*** 监听端口号* server.on('error', onError) 这行代码添加了一个事件监听器,用于处理服务器启动过程中可能出现的错误。当服务器启动过程中发生错误时,会触发 error 事件,然后调用 onError 函数进行处理。* server.on('listening', onListening); 这行代码添加了一个事件监听器,用于处理服务器成功启动并开始监听指定端口的情况。当服务器成功开始监听指定端口时,会触发 listening 事件,然后调用 onListening 函数进行处理。*/server.listen(port);
server.on('error', onError);
server.on('listening', onListening);/***将端口规范化为数字、字符串或false。port = parseInt(val, 10); 这是 JavaScript 中的一个函数,用于将字符串转换为整数。它接受两个参数,第一个参数是要转换的字符串,第二个参数是表示要转换的进制数,这里的 10 表示使用十进制数进行转换。*/function normalizePort(val) {var port = parseInt(val, 10);if (isNaN(port)) {// named pipe  可能是一种命名管道(named pipe)形式return val;}if (port >= 0) {// port numberreturn port;}return false;
}/*** Event listener for HTTP server "error" event.* 监听http服务error的事件*/function onError(error) {//这行代码判断错误对象 error 的 syscall 属性是否等于 'listen'。在 Node.js 中,当一个错误发生时,通常会包含一个 syscall 属性,用于指示发生错误的系统调用。如果发生的错误不是由监听系统调用引起的,那么就会执行接下来的操作。if (error.syscall !== 'listen') {throw error;}var bind = typeof port === 'string'? 'Pipe ' + port: 'Port ' + port;// handle specific listen errors with friendly messagesswitch (error.code) {case 'EACCES':  // 如果错误代码是 'EACCES',表示出现了权限不足的错误。在这种情况下,代码会输出错误信息并退出进程,返回一个非零的退出码(1),以表示启动失败。console.error(bind + ' requires elevated privileges');process.exit(1);break;case 'EADDRINUSE': //如果错误代码是 'EADDRINUSE',表示端口已被占用。在这种情况下,代码同样会输出错误信息并退出进程。console.error(bind + ' is already in use');process.exit(1);break;default:throw error;}
}/*** Event listener for HTTP server "listening" event.* 监听http服务listening事件*/function onListening() {var addr = server.address();var bind = typeof addr === 'string'? 'pipe ' + addr: 'port ' + addr.port;debug('Listening on ' + bind);
}
db/index.js
var mongoose = require('mongoose');
//链接数据库,数据库的默认端口是27017;Mango为
mongoose.connect("mongodb://127.0.0.1:27017/Mango"); var db = mongoose.connection;
db.on('error',console.error.bind(console,'connection error:'));
db.once('open',function(){console.log('数据库连接成功');
})// 注册模块
var userSchema = new mongoose.Schema({username : String,//用户名password : String,//登录密码
})
var User = mongoose.model("users",userSchema)
module.exports = {User
}   

mongodb:// 是连接 MongoDB 的协议。
127.0.0.1 是本地主机的 IP 地址,表示连接到本地计算机上运行的 MongoDB 服务器。如果 MongoDB 服务器运行在不同的主机上,你需要将 IP 地址替换为相应主机的 IP 地址。
27017 是 MongoDB 默认的端口号。
Mango 是数据库的名称。如果该数据库不存在,MongoDB 将会自动创建它。

router/user/User.js

这里写一个注册的接口

var express = require('express');
var { User } = require('../../db');
var router = express.Router();
// 注册模块
router.post('/register',function(req,res,next){let form = req.body;User.find( form ).then(rel =>{if(rel.length > 0){res.json({code : 0,message : '用户名已存在'})}else{User.create( form ).then(rel =>{if(rel){res.json({code : 0,message : '注册成功'})}else{res.json({code : 1,message : '注册失败'})}})}}).catch(err =>{console.error(err)res.json({code : 0,message : '注册时出现异常'})})
})module.exports = router;
app.js
var createError = require('http-errors');
var express = require('express');
var app = express();
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');  //日志
var cors = require('cors') //  为了能在前端调用,必须实现跨域,我们采用Node.js里的cors模块在后端实现跨域   npm install cors --save
require("./db/index.js")
// var indexRouter = require('./router/index');// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');app.use(cors()) // 调用cors模块,允许跨域
app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));const userRouter = require('./router/user/User.js');
//注意这里路由可以是随意写,但是需要注意的地方是,在前端进行请求时,例如:XXXX/user/register的访问接口,如果这里的路由是:/api/user,则前端访问的接口就是:XXXX/api/user/register。总的来说就是,这里use定义的路由 + User.js中post那里定义的路由,就是前端要访问的路由。
app.use( "/user", userRouter)
// catch 404 and forward to error handler
app.use(function(req, res, next) {next(createError(404));
});// error handler
app.use(function(err, req, res, next) {// set locals, only providing error in developmentres.locals.message = err.message;res.locals.error = req.app.get('env') === 'development' ? err : {};// render the error pageres.status(err.status || 500);res.render('error');
});module.exports = app;

前端项目

跨域

因为后端的域名和端口会不一样,所以需要前端配置允许跨域,在项目中找到vue.config.js文件,这里我使用proxy来实现跨域

  devServer:{ // 开发环境的相关的配置static: {directory: path.join(__dirname, 'public'), // 静态资源目录}, proxy: {'/api': {target: 'http://localhost:4000', // 实际请求的后端地址changeOrigin: true,pathRewrite: {'^/api': '' // 重写请求地址,将/api开头的路径替换为空},logLevel: 'debug'}}},

request.js文件中

重置axios请求,实现请求拦截功能

// axios请求拦截相关配置
import NProgress from 'nprogress';  // 导入前先安装npm install nprogress --save
import 'nprogress/nprogress.css'
import BASE_URL from '../../config/index'
import axios from 'axios'
const instance = axios.create({baseURL: BASE_URL,timeout: 5000,headers: {// 'token': sessionStorage.getItem('token'),// 'Access-Control-Allow-Origin':'*'} //请求接口时带上token});// 添加请求拦截器
instance.interceptors.request.use(function (config) {// 在发送请求之前做些什么NProgress.start()return config;
}, function (error) {// 对请求错误做些什么NProgress.done()return Promise.reject(error);
});// 添加响应拦截器
instance.interceptors.response.use(function (response) {// 2xx 范围内的状态码都会触发该函数。// 对响应数据做点什么NProgress.done()return response;
}, function (error) {// 超出 2xx 范围的状态码都会触发该函数。// 对响应错误做点什么NProgress.done()return Promise.reject(error);
});let get = async function(url,params){
let {data} = await instance.get(url,params)
return data
}
let post =async function(url,params){let {data} = await instance.post(url,params)return data
}// 创建一个将token信息保存到请求头的方法
let setToken = () => {instance.defaults.headers.common['token'] = '123'
}
export {get , post,setToken
}

myPlugin.js文件

这里实现一个简单的插件,使用vue的mixin混入,将get请求和post请求等方法混入到vue中,这样在任何组件中都可以使用this.$get()来访问get方法,同理mixin混入的方法都能用this访问到

/* eslint-disable no-unused-vars */
/* eslint-disable no-undef */
import {get, post,setToken} from '../utils/request'//定义一个插件
export default {// 插件中,必须包含一个install方法install: function(Vue){// 给vue混入成员Vue.mixin({methods:{$get(url,params){return get(url,params)},$post(url,params){return post(url,params)},$setToken(){// 执行该方法,就会将浏览器缓存里面的token信息存到ajax的请求头中setToken()},// 成功消息框$msg_s(message,duration=3000){this.$message({// 显示关闭图标showClose:true,message,type:"success",duration})},// 警告消息框$msg_w(message,duration=3000){this.$message({// 显示关闭图标showClose:true,message,type:"warning",duration})},// 错误消息框$msg_e(message,duration=3000){this.$message({// 显示关闭图标showClose:true,message,type:"error",duration})},// 确认框$con_f(message){return this.$confirm(message).then( res => {return true}).catch((_) => {});}}})}
}

registerView.vue组件中

在注册页面中,输入登录名和登录密码,点击确认按钮时,调用后台的接口/user/register。这里的api是proxy配置跨域时的重写,不是后台接口app.use()定义的接口出现的api,这里不要搞混了。如果后台app.js中app.use( "/api/user", userRouter)这样定义,则前端访问时应该:let res = await this.$post('/api/api/user/register',this.loginForm)

submitForm(formName) {this.$refs[formName].validate(async(valid) => {if (valid) {let res = await this.$post('/api/user/register',this.loginForm);// this.$router.push('/login')} else {return false;}});},

查看数据库中注册的用户信息

在这里插入图片描述
点击上图,打开mogoodb;

在这里插入图片描述
以上便是注册的用户信息。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/808455.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二分查找-图文详解,看不懂你来打我。。。

一、查找算法 在计算机科学和算法领域,搜索是一项基本的任务。在海量数据中寻找特定的元素是一项常见的任务,而二分查找(Binary Search)是一种非常高效的搜索算法,特别适用于有序数组。 二、二分查找 二分查找是一种…

git:常用cmd命令

一、cmd 查看本地分支&#xff1a; git branch 切换分支 git checkout <分支名> 拉取指定分支的代码 git pull origin <分支名> 合并指定分支的代码 git merge <branch-name> 提交代码&#xff08;查看是否有冲突&#xff09; git commit -m &quo…

【24届数字IC秋招总结】提前批面试经验2——芯动、兆易创新、地平线

文章目录 前言一、兆易创新-逻辑设计验证工程师1.1 一面面试问题1.2 二面面试问题1.3 三面面试问题二、地平线-IP验证工程师2.1 面试问题三、芯动科技-数字IC验证工程师3.1 一面面试问题3.2 二面面试问题前言 提前批面试公司:芯动、兆易创新、地平线 一、兆易创新-逻辑设计验…

Java日期正则表达式(附Demo)

目录 前言1. 基本知识2. Demo 前言 对于正则匹配&#xff0c;在项目实战中运用比较广泛 原先写过一版Python相关的&#xff1a;ip和端口号的正则表达式 1. 基本知识 对于日期的正则相对比较简单 以下是一些常见的日期格式及其对应的正则表达式示例&#xff1a; 年-月-日&a…

React复习全攻略:浅尝Redux的全局滋味

是什么? Redux 是一个使用叫做 “action” 的事件来管理和更新应用状态的模式和工具库 提供全局状态数据的单一仓库&#xff08;对象树&#xff09;&#xff0c;管理应用的全局状态单一数据源&#xff0c;状态只读&#xff0c;状态修改只由纯函数完成 为什么用&#xff08;特点…

关于游戏当中击退/击飞效果的制作

关于游戏当中击退/击飞效果的制作 在游戏当中我们免不了会有一些炫酷的效果&#xff0c;特别是RPG游戏&#xff0c;比如放一个技能&#xff0c;直接大范围杀伤&#xff0c;然后把敌人全部击飞或者击退&#xff0c;那效果真的很舒服。把自己想象成武林高手&#xff0c;一套江湖…

常用的深度学习自动标注软件

0. 简介 自动标注软件是一个非常节省人力资源的操作&#xff0c;而随着深度学习的发展&#xff0c;这些自动化标定软件也越来越多。本文章将会着重介绍其中比较经典的自动标注软件 1. AutoLabelImg AutoLabelImg 除了labelimg的初始功能外&#xff0c;额外包含十多种辅助标注…

五、书架开发--1.书架标题组件交互、获取书架数据

添加书架页面&#xff0c;做路由配置 首先添加书架页面&#xff0c;到views中的store中添加一个StoreShelf表示书架 然后到路由中进行注册 然后书城首页的返回键我们是想要点击返回的话就跳转到书架页面&#xff0c;所以如下this.$router.push(/store/shelf) 做书架标题组件 …

mybatis-plus笔记BaseMapper/ServiceImpl/IService/@TableName/@TableId@分页模糊查询

1、BaseMapper是mybatis-plus提供的&#xff0c;汇聚插入、更新、删除和查询等功能&#xff0c;简化sql代码。 2、ServiceImpl 是IService 的实现类&#xff0c;有两个泛型参数&#xff0c;一个参数为BaseMapper 也就是实体Mapper &#xff0c;一个是实体类。 3、IService接口中…

d3dcompiler_47.dll文件的缺失问题要怎么解决?四种修复d3dcompiler_47.dll的方法

d3dcompiler_47.dll文件的丢失&#xff0c;其实还是比较少见的&#xff0c;毕竟这个dll文件相对来说还是比较稳定的&#xff0c;他是一个固定软件的一个功能dll文件&#xff0c;不过既然这个d3dcompiler_47.dll丢失了&#xff0c;今天我们就来给大家详细的说一说吧。 一.d3dcom…

“人工智能+数字人”,让数字技术赋能多领域智能化管理、数字化服务

AI数字人结合了语音合成、语音识别、语义理解、图像处理、虚拟形象驱动等多项AI核心技术&#xff0c;可以实现导览服务、信息播报、互动交流、业务咨询等智能化功能。 如今&#xff0c;AI数字人逐渐被政务、文旅、展馆展厅、博物馆、数字会议、金融、校园等等领域多元化应用&am…

基于JavaScript的简单RPC原理演示

创建RPC服务器 const WebSocket require(ws); class RPCServer { constructor(port) { this.wss new WebSocket.Server({ port }); this.methods {}; this.wss.on(connection, (ws) > this.handleConnection(ws)); } registerMethod(name, callback) { this.meth…

猝不及防 CCF-B ICPP 2024投稿延期至4月22日提交摘要 机会来了别错过

会议之眼 快讯 第53届ICPP&#xff08;International Conference on Parallel Processing&#xff09;即国际并行处理会议将于 2024年 8月12日-15日在瑞典哥特兰岛举行&#xff01;ICPP是世界上最古老的连续举办的并行计算计算机科学会议之一。它是学术界、工业界和政府的研究…

git修改本地提交历史邮箱地址

1、Git&#xff08;Git&#xff09; 2、修改Git本地提交历史中的邮箱地址 使用 git rebase 命令进行交互式重置。 具体步骤如下&#xff1a;&#xff08;https://git-scm.com/docs/git-rebase&#xff09; 1、查看提交历史&#xff1a; 使用 git log 命令列出提交历史&#x…

fs.1.10 ON CENTOS7 dockerfile模式

概述 freeswitch是一款简单好用的VOIP开源软交换平台。 centos7 docker上编译安装fs.1.10的流程记录&#xff0c;本文使用dockerfile模式。 环境 docker engine&#xff1a;Version 24.0.6 centos docker&#xff1a;7 freeswitch&#xff1a;v1.10.7 dockerfile 创建空…

4月11号总结

java学习 一.io流 简介&#xff1a;io&#xff0c;i代表in&#xff0c;指的是输入&#xff0c;o代表输出。io流是用于处理输入和输出数据的机制。Java的io流主要分为字节流和字符流两种类型。这些流可以用于读取和写入不同类型的数据&#xff0c;如文本&#xff0c;图片&#…

闲谈2024(一)

时光飞逝&#xff0c;一转眼24年的第一个季度已经过去了&#xff0c;回望这3个多月&#xff0c;感触颇多。首先&#xff0c;24年从一个一心只读圣贤书&#xff0c;全身心投入在技术上的研发工程师&#xff0c;转变为一个团队的小leader。从我个人对自己的定位来说&#xff0c;我…

【洛谷】P1216 数字三角形

import java.io.IOException; import java.util.Scanner;public class P1216_数字三角形_DP_原版 {public static void main(String[] args) {Scanner sc new Scanner(System.in);int n sc.nextInt();int[][] dp new int[n 1][n 1];int t;for (int i 1; i < n; i) {fo…

Ollama教程——兼容OpenAI API:高效利用兼容OpenAI的API进行AI项目开发

相关文章: Ollama教程——入门&#xff1a;开启本地大型语言模型开发之旅 Ollama教程——模型&#xff1a;如何将模型高效导入到ollama框架 Ollama教程——兼容OpenAI API&#xff1a;高效利用兼容OpenAI的API进行AI项目开发 Ollama教程——兼容OpenAI API&#xff1a;高效利用…

推荐一个大学生可以参加的榜单赛事|人工智能赛道

【榜单赛事】第十四届全国大学生计算机应用能力与数字素养大赛 - 人工智能产业应用赛道人工智能编程赛项 正在火热报名中 本赛道定位于人工智能产业应用和实践&#xff0c;把人工智能产业真实的技能要求、能力要求体现在竞赛内容设计当中&#xff0c;并在竞赛环节融入实战项目…