node.js +mongdb實現(xiàn)登錄功能
一、開發(fā)環(huán)境準(zhǔn)備
npm init -y //初始化倉庫 npm i koa koa-router -S //安裝koa和路由模塊 npm i nodemon -S
二、開啟node服務(wù)
//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
四、拆分路由系統(tǒng)

//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);
五、初始化項目的配置文件

//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設(shè)計項目結(jié)構(gòu)
model -->數(shù)據(jù)層 views -->視圖層 controllers -->視圖控制層

//routers--index.js
const router = require("koa-router")();
const controllers = require("../controllers");
// 只寫文件名默認(rèn)會讀取文件里的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.進(jìn)行項目的配置
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;
});
八、連接數(shù)據(jù)庫
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);
// 數(shù)據(jù)庫中有對應(yīng)的用戶名密碼則數(shù)組有東西,沒有則數(shù)組沒東西
if(data.length>0){
/* 登錄成功 */
ctx.body = "登錄成功"
}else{
ctx.body = "用戶名和密碼不存在"
}
}
總結(jié)
到此這篇關(guān)于node.js +mongdb實現(xiàn)登錄功能的文章就介紹到這了,更多相關(guān)node.js mongdb實現(xiàn)登錄內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Windows系統(tǒng)下使用Sublime搭建nodejs環(huán)境
最近在研究Nodejs開發(fā),俗話說,工欲善其事,必先利其器,當(dāng)然要找到一款用著順手的編輯器作為開始。這里我們選擇的是Sublime Text 3,除了漂亮的用戶界面,最吸引我的就是它的插件擴(kuò)展功能以及跨平臺特性。2015-04-04
Nodejs訪問網(wǎng)絡(luò)并解析返回的json的實現(xiàn)方法
本文主要介紹了Nodejs訪問網(wǎng)絡(luò)并解析返回的json的實現(xiàn)方法,文中根據(jù)實例編碼詳細(xì)介紹的十分詳盡,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
Node.js創(chuàng)建一個Express服務(wù)的方法詳解
這篇文章主要介紹了Node.js創(chuàng)建一個Express服務(wù)的方法,結(jié)合實例形式分析了node.js創(chuàng)建Express服務(wù)的具體步驟、實現(xiàn)方法及相關(guān)操作技巧,需要的朋友可以參考下2020-01-01
nodejs個人博客開發(fā)第六步 數(shù)據(jù)分頁
這篇文章主要為大家詳細(xì)介紹了nodejs個人博客開發(fā)的數(shù)據(jù)分頁,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04
nodejs如何獲取當(dāng)前連接的網(wǎng)絡(luò)ip
這篇文章主要介紹了nodejs如何獲取當(dāng)前連接的網(wǎng)絡(luò)ip問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10
Node中完整的?node?addon?實現(xiàn)流程
這篇文章主要介紹了Node中完整的node?addon實現(xiàn)流程,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-09-09

