Koa項(xiàng)目搭建過(guò)程詳細(xì)記錄
本文介紹了Koa項(xiàng)目搭建過(guò)程詳細(xì)記錄,分享給大家,具體如下:
Java中的Spring MVC加MyBatis基本上已成為Java Web的標(biāo)配。Node JS上對(duì)應(yīng)的有Koa、Express、Mongoose、Sequelize等。Koa一定程度上可以說(shuō)是Express的升級(jí)版。許多Node JS項(xiàng)目已開(kāi)始使用非關(guān)系型數(shù)據(jù)庫(kù)(MongoDB)。Sequelize對(duì)非關(guān)系型數(shù)據(jù)庫(kù)(MSSQL、MYSQL、SQLLite)做了支持。
Koa項(xiàng)目構(gòu)建
cnpm install -g koa-generator // 這里一定要用koa2 koa2 /foo
Koa常用中間件介紹
koa-generator生成的應(yīng)用已經(jīng)包含常用中間件了,這里僅說(shuō)它里面沒(méi)有用到的。
koa-less
app.use(require('koa-less')(__dirname + '/public'))
必須在static前use,不然會(huì)無(wú)效。
stylesheets文件夾下新建styles.less,并引入所有模塊化less文件。
@import 'foo.less'; @import 'bar.less';
這樣所有的樣式會(huì)被編譯成一個(gè)style.css。在模板(pug)中引用style.css就行了。
koa-session
// 設(shè)置app keys,session會(huì)根據(jù)這個(gè)進(jìn)行加密 app.keys = ['some secret hurr']; // 配置session config const CONFIG = { key: 'bougie:session', /** (string) cookie key (default is koa:sess) */ maxAge: 1000 * 60 * 60 * 24 * 7, overwrite: true, /** (boolean) can overwrite or not (default true) */ httpOnly: true, /** (boolean) httpOnly or not (default true) */ signed: true, /** (boolean) signed or not (default true) */ rolling: true, /** (boolean) Force a session identifier cookie to be set on every response. The expiration is reset to the original maxAge, resetting the expiration countdown. (default is false) */ renew: false, /** (boolean) renew session when session is nearly expired, so we can always keep user logged in. (default is false)*/ }; // 應(yīng)用中間件 app.use(session(CONFIG, app));
這個(gè)必須在router前use,不然會(huì)無(wú)效。
基本使用,可以當(dāng)成一個(gè)普通對(duì)象
// 賦值 ctx.session.statu = value // 取值 ctx.session.statu // 刪除 ctx.session.statu = null
koa-proxies
用于代理配置
const proxy = require('koa-proxies') app.use(proxy('/octocat', { target: 'https://api.github.com/users', changeOrigin: true, agent: new httpsProxyAgent('http://1.2.3.4:88'), rewrite: path => path.replace(/^\/octocat(\/|\/\w+)?$/, '/vagusx'), logs: true }))
路由控制
開(kāi)發(fā)主要集中在路由控制這里,包括restful接口和模板渲染
獲取參數(shù)(request)
查詢(xún)參數(shù)(?param=a)
ctx.query.param
路由參數(shù)(/:id)
ctx.params.id
POST參數(shù)(JSON或Form)
ctx.request.body
請(qǐng)求回應(yīng)(response)
服務(wù)器響應(yīng)給客戶(hù)端的數(shù)據(jù)
restful
ctx.body = yourData
模板渲染
默認(rèn)從views目錄開(kāi)始,不許加文件后綴
ctx.render('layout', yourData)
路由攔截
未登錄時(shí)拒絕請(qǐng)求,這樣會(huì)返回404
const userAuth = (ctx, next) => { let isLogin = ctx.session.isLogin if(isLogin) return next() } router.use('/', userAuth)
此操作會(huì)包含在路由,如"/a"、"/b"等,需在子路由之前use,不然會(huì)無(wú)效
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Node.js連接postgreSQL并進(jìn)行數(shù)據(jù)操作
自從MySQL被Oracle收購(gòu)以后,PostgreSQL逐漸成為開(kāi)源關(guān)系型數(shù)據(jù)庫(kù)的首選。這篇文章就給大家介紹了關(guān)于Node.js如何連接postgreSQL數(shù)據(jù)庫(kù),并進(jìn)行數(shù)據(jù)操作的方法,有需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。2016-12-12node.js使用stream模塊實(shí)現(xiàn)自定義流示例
這篇文章主要介紹了node.js使用stream模塊實(shí)現(xiàn)自定義流,結(jié)合實(shí)例形式詳細(xì)分析了node.js基于stream模塊實(shí)現(xiàn)自定義的可讀流、可寫(xiě)流、可讀寫(xiě)流等相關(guān)操作技巧,需要的朋友可以參考下2020-02-02Nodejs如何進(jìn)行性能監(jiān)控和分析優(yōu)化
Node.js應(yīng)用可能因?yàn)楦卟l(fā)、內(nèi)存泄漏、CPU密集型任務(wù)等原因?qū)е滦阅芟陆?影響用戶(hù)體驗(yàn)甚至系統(tǒng)穩(wěn)定性,通過(guò)性能監(jiān)控和分析,我們可以及時(shí)發(fā)現(xiàn)潛在問(wèn)題,并針對(duì)性地進(jìn)行優(yōu)化,確保系統(tǒng)正常運(yùn)行且具備良好的性能表現(xiàn)2024-06-06sublime text配置node.js調(diào)試(圖文教程)
下面小編就為大家分享一篇sublime text配置node.js調(diào)試(圖文教程),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-11-11