node.js +mongdb实现登录功能


Posted in Javascript onJune 18, 2020

一、开发环境准备

npm init -y //初始化仓库
npm i koa koa-router -S //安装koa和路由模块
npm i nodemon -S

二、开启node服务

//index.js
const koa = require("koa");
const router = require("koa-router")();
const app = new koa();
router.get("/",async ctx=>{
 ctx.body = "我是首页"
})
app.use(router.routes());
app.listen(8080);

三、配置art-template

3-1 安装依赖

npm install koa-art-template art-template -S

四、拆分路由系统

node.js +mongdb实现登录功能

//routers-index.js
const router = require("koa-router")();
router.get("/", async ctx => {
 await ctx.render('index');
})
module.exports = router;
//index.js
const koa = require("koa");
const router = require('./routers/index.js');
const render = require('koa-art-template');
const app = new koa();
const path = require("path");
render(app, {
 root: path.join(__dirname, 'views'),
 extname: '.html',
 debug: process.env.NODE_ENV !== 'production'
});

app.use(router.routes());
app.listen(8080);

五、初始化项目的配置文件

node.js +mongdb实现登录功能

//init-config.js
const path = require("path");
const render = require('koa-art-template');
const router = require('../routers/index');
function initConfig(app) {
 // process.cwd()可以读取项目的路径
 render(app, {
  root: path.join(process.cwd(), 'views'),
  extname: '.html',
  debug: process.env.NODE_ENV !== 'production'
 });

 app.use(router.routes());
}
module.exports = initConfig;
//index.js
const koa = require("koa");
const app = new koa();
let initConfig = require('./init/config');
initConfig(app);
app.listen(8080);

六、MVC设计项目结构

model -->数据层
views -->视图层
controllers -->视图控制层

node.js +mongdb实现登录功能

//routers--index.js
const router = require("koa-router")();
const controllers = require("../controllers");
// 只写文件名默认会读取文件里的index.js
router.get("/", controllers.index)
module.exports = router;
//controller--index.js
let index = async ctx=>{
 await ctx.render('index');
}
module.exports = {
 index
}

七、获取post传值

//1.安装依赖
npm i koa-bodyparser -S
//2.进行项目的配置
var Koa = require('koa');
var bodyParser = require('koa-bodyparser');

var app = new Koa();
app.use(bodyParser());

app.use(async ctx => {
 //3.取值 ctx.request.body
 ctx.body = ctx.request.body;
});

八、连接数据库

npm i mongoose -S
//models --db.js
const mongoose = require('mongoose');
mongoose.connect( 'mongodb://127.0.0.1:27017/studentManage', {useNewUrlParser: true},(err)=>{
 if(err) throw err;
 console.log("database连接成功")
});
module.exports = mongoose;
//models --user.js
var mongoose = require('./db');
var UserSchema = new mongoose.Schema({
 name:String,
 pwd:String
})
var User = mongoose.model('User',UserSchema,'user');
module.exports = User;
//controllers -- index.js
let doLogin = async ctx=>{
 let {user,pwd} = ctx.request.body;
 let data = await UserModel.find({name:user,pwd});
 console.log(data);
 // 数据库中有对应的用户名密码则数组有东西,没有则数组没东西
 if(data.length>0){
  /* 登录成功 */
  ctx.body = "登录成功"
 }else{
  ctx.body = "用户名和密码不存在"
 } 
}

总结

到此这篇关于node.js +mongdb实现登录功能的文章就介绍到这了,更多相关node.js mongdb实现登录内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
JS小框架 fly javascript framework
Nov 26 Javascript
JS获取并操作iframe中元素的方法
Mar 21 Javascript
JS+CSS实现带关闭按钮DIV弹出窗口的方法
Feb 27 Javascript
分享自己用JS做的扫雷小游戏
Feb 17 Javascript
jQuery实现单击按钮遮罩弹出对话框效果(1)
Feb 20 Javascript
Bootstrap面板(Panels)的简单实现代码
Mar 17 Javascript
详解用webpack把我们的业务模块分开打包的方法
Jul 20 Javascript
vue keep-alive请求数据的方法示例
May 16 Javascript
vsCode安装使用教程和插件安装方法
Aug 24 Javascript
JavaScript学习笔记之DOM操作实例分析
Jan 08 Javascript
Vue keepAlive 数据缓存工具实现返回上一个页面浏览的位置
May 10 Javascript
JavaScript array常用方法代码实例详解
Sep 02 Javascript
VSCode launch.json配置详细教程
Jun 18 #Javascript
JavaScript中使用Spread运算符的八种方法总结
Jun 18 #Javascript
通过实例了解JS执行上下文运行原理
Jun 17 #Javascript
从0搭建vue-cli4脚手架
Jun 17 #Javascript
微信小程序点击生成朋友圈分享图(遇到的坑)
Jun 17 #Javascript
基于JS+HTML实现弹窗提示是否确认提交功能
Jun 17 #Javascript
vue移动端的左右滑动事件详解
Jun 17 #Javascript
You might like
PHP中其实也可以用方法链
2011/11/10 PHP
基于MySQL分区性能的详细介绍
2013/05/02 PHP
PHP curl 抓取AJAX异步内容示例
2014/09/09 PHP
Thinkphp搜索时首页分页和搜索页保持条件分页的方法
2014/12/05 PHP
php通过function_exists检测函数是否存在的方法
2015/03/18 PHP
ThinkPHP中html:list标签用法分析
2016/01/09 PHP
PHP的PDO常用类库实例分析
2016/04/07 PHP
php parse_str() 函数的定义和用法
2016/05/23 PHP
JS 屏蔽键盘不可用与鼠标右键不可用的方法
2013/11/18 Javascript
多引号嵌套的变量命名的问题
2014/05/09 Javascript
JS简单实现城市二级联动选择插件的方法
2015/08/19 Javascript
模仿password输入框的实现代码
2016/06/07 Javascript
AngularJS中directive指令使用之事件绑定与指令交互用法示例
2016/11/22 Javascript
关于不同页面之间实现参数传递的几种方式讨论
2017/02/13 Javascript
jQuery设计思想
2017/03/07 Javascript
jQuery实现checkbox全选功能完整实例
2018/07/12 jQuery
详解关于element级联选择器数据回显问题
2019/02/20 Javascript
vue实现用户长时间不操作自动退出登录功能的实现代码
2020/07/23 Javascript
Javascript如何实现扩充基本类型
2020/08/26 Javascript
vue+Element-ui实现登录注册表单
2020/11/17 Javascript
Vue页面渲染中key的应用实例教程
2021/01/12 Vue.js
[03:04]DOTA2英雄基础教程 影魔
2013/12/11 DOTA
Python模拟登录验证码(代码简单)
2016/02/06 Python
python 简单的绘图工具turtle使用详解
2017/06/21 Python
pycharm 将django中多个app放到同个文件夹apps的处理方法
2018/05/30 Python
详解如何用django实现redirect的几种方法总结
2018/11/22 Python
pandas DataFrame创建方法的方式
2019/08/02 Python
python openvc 裁剪、剪切图片 提取图片的行和列
2019/09/19 Python
python 字符串格式化的示例
2020/09/21 Python
python 自定义异常和主动抛出异常(raise)的操作
2020/12/11 Python
J2SDK1.5与J2SDK5.0有什么区别
2012/09/19 面试题
大学生护理专业自荐信
2013/10/03 职场文书
高二历史教学反思
2014/01/25 职场文书
幼儿园安全责任书范本
2014/07/24 职场文书
MySQL查询日期时间
2022/05/15 MySQL
Windows Server 2008配置防火墙策略详解
2022/06/28 Servers