Koa项目搭建过程详细记录


Posted in Javascript onApril 12, 2018

本文介绍了Koa项目搭建过程详细记录,分享给大家,具体如下:

Koa项目搭建过程详细记录

Java中的Spring MVC加MyBatis基本上已成为Java Web的标配。Node JS上对应的有Koa、Express、Mongoose、Sequelize等。Koa一定程度上可以说是Express的升级版。许多Node JS项目已开始使用非关系型数据库(MongoDB)。Sequelize对非关系型数据库(MSSQL、MYSQL、SQLLite)做了支持。

Koa项目构建

cnpm install -g koa-generator

// 这里一定要用koa2
koa2 /foo

Koa常用中间件介绍

koa-generator生成的应用已经包含常用中间件了,这里仅说它里面没有用到的。

koa-less

app.use(require('koa-less')(__dirname + '/public'))

必须在static前use,不然会无效。

stylesheets文件夹下新建styles.less,并引入所有模块化less文件。

@import 'foo.less';
@import 'bar.less';

这样所有的样式会被编译成一个style.css。在模板(pug)中引用style.css就行了。

koa-session

// 设置app keys,session会根据这个进行加密
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)*/
};

// 应用中间件
app.use(session(CONFIG, app));

这个必须在router前use,不然会无效。

基本使用,可以当成一个普通对象

// 赋值
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
}))

路由控制

开发主要集中在路由控制这里,包括restful接口和模板渲染

获取参数(request)

查询参数(?param=a)

ctx.query.param

路由参数(/:id)

ctx.params.id

POST参数(JSON或Form)

ctx.request.body

请求回应(response)

服务器响应给客户端的数据

restful

ctx.body = yourData

模板渲染

默认从views目录开始,不许加文件后缀

ctx.render('layout', yourData)

路由拦截

未登录时拒绝请求,这样会返回404

const userAuth = (ctx, next) => {
  let isLogin = ctx.session.isLogin
  if(isLogin) return next()
}
router.use('/', userAuth)

此操作会包含在路由,如"/a"、"/b"等,需在子路由之前use,不然会无效

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
深入理解Javascript闭包 新手版
Dec 28 Javascript
用Javascript来生成ftp脚本的小例子
Jul 03 Javascript
js特殊字符转义介绍
Nov 05 Javascript
Javascript中的getUTCHours()方法使用详解
Jun 10 Javascript
JavaScript的Backbone.js框架入门学习指引
May 07 Javascript
js实现表单提交后不重新刷新当前页面
Nov 30 Javascript
Vue学习笔记进阶篇之vue-router安装及使用方法
Jul 19 Javascript
Vue精简版风格指南(推荐)
Jan 30 Javascript
基于javascript的拖拽类封装详解
Apr 19 Javascript
js+canvas实现纸牌游戏
Mar 16 Javascript
JQuery基于FormData异步提交数据文件
Sep 01 jQuery
解决vue打包 npm run build-test突然不动了的问题
Nov 13 Javascript
React props和state属性的具体使用方法
Apr 12 #Javascript
react-native 圆弧拖动进度条实现的示例代码
Apr 12 #Javascript
关于vue中 $emit的用法详解
Apr 12 #Javascript
Vue 页面跳转不用router-link的实现代码
Apr 12 #Javascript
JS中promise化微信小程序api
Apr 12 #Javascript
vue配置请求本地json数据的方法
Apr 11 #Javascript
jQuery实现判断上传图片类型和大小的方法示例
Apr 11 #jQuery
You might like
php基于session实现数据库交互的类实例
2015/08/03 PHP
PHP文字转图片功能原理与实现方法分析
2017/08/31 PHP
JavaScript语句可以不以;结尾的烦恼
2007/03/08 Javascript
javascript 导出数据到Excel(处理table中的元素)
2009/12/18 Javascript
JQuery优缺点分析说明
2010/06/09 Javascript
js查找某元素中的所有图片地址的方法
2014/01/16 Javascript
AngularJS入门教程之多视图切换用法示例
2016/11/02 Javascript
微信小程序 后台https域名绑定和免费的https证书申请详解
2016/11/10 Javascript
jQuery实现表格元素动态创建功能
2017/01/09 Javascript
Vue.js实现模拟微信朋友圈开发demo
2017/04/20 Javascript
微信小程序实现给循环列表添加点击样式实例
2017/04/26 Javascript
PHP实现记录代码运行时间封装类实例教程
2017/05/08 Javascript
bootstrap paginator分页前后台用法示例
2017/06/17 Javascript
JS+H5 Canvas实现时钟效果
2018/07/20 Javascript
React中this丢失的四种解决方法
2019/03/12 Javascript
Vue开发环境中修改端口号的实现方法
2019/08/15 Javascript
Python实现备份文件实例
2014/09/16 Python
Python实现简单截取中文字符串的方法
2015/06/15 Python
python 提取tuple类型值中json格式的key值方法
2018/12/31 Python
Django组件cookie与session的具体使用
2019/06/05 Python
python实现从本地摄像头和网络摄像头截取图片功能
2019/07/11 Python
pyinstaller参数介绍以及总结详解
2019/07/12 Python
python3 实现函数写文件路径的正确方法
2019/11/27 Python
python 5个顶级异步框架推荐
2020/09/09 Python
python用Configobj模块读取配置文件
2020/09/26 Python
Java中实现多态的机制
2015/08/09 面试题
护士自荐信怎么写
2013/10/18 职场文书
我的动漫时代的创业计划书范文
2014/01/27 职场文书
挂牌仪式主持词
2014/03/20 职场文书
二年级学生评语大全
2014/04/23 职场文书
党员教师群众路线对照检查材料思想汇报
2014/09/29 职场文书
2015年为民办实事工作总结
2015/05/26 职场文书
奠基仪式致辞
2015/07/30 职场文书
2016年教师节感恩寄语
2015/12/04 职场文书
民政局2016年“六一”儿童节慰问活动总结
2016/04/06 职场文书
js实现模拟购物商城案例
2021/05/18 Javascript