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 可以拖动的DIV(二)
Jun 26 Javascript
在jQuery中 常用的选择器介绍
Apr 16 Javascript
node.js中的console.time方法使用说明
Dec 09 Javascript
javascript实现的猜数小游戏完整实例代码
May 10 Javascript
jQuery基础_入门必看知识点
Jul 04 Javascript
浅谈使用splice函数对数组中的元素进行删除时的注意事项
Dec 04 Javascript
js+html5实现半透明遮罩层弹框效果
Aug 24 Javascript
基于JavaScript实现表格滚动分页
Nov 22 Javascript
JS/jQuery实现DIV延时几秒后消失或显示的方法
Feb 12 jQuery
layer弹出层 iframe层去掉滚动条的实例代码
Aug 17 Javascript
jQuery解析json格式数据示例
Sep 01 jQuery
深入理解es6块级作用域的使用
Mar 28 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
Codeigniter控制器controller继承问题实例分析
2016/01/19 PHP
创建无限极分类树型结构的简单方法
2017/06/20 PHP
用js+xml自动生成表格的东西
2006/12/21 Javascript
JavaScript中的运算符种类及其规则介绍
2013/09/26 Javascript
javascript 实现字符串反转的三种方法
2013/11/23 Javascript
分析js闭包引起的事件注册问题
2016/03/29 Javascript
AngularJS 与百度地图的结合实例
2016/10/20 Javascript
JavaScript自定义浏览器滚动条兼容IE、 火狐和chrome
2017/01/05 Javascript
js实现微博发布小功能
2017/01/12 Javascript
微信小程序 天气预报开发实例代码源码
2017/01/20 Javascript
canvas实现探照灯效果
2017/02/07 Javascript
angularJS深拷贝详解
2017/03/23 Javascript
AngularJS 实现点击按钮获取验证码功能实例代码
2017/07/13 Javascript
js实现图片上传预览原理分析
2017/07/13 Javascript
Bootstrap Table中的多选框删除功能
2018/07/15 Javascript
基于ssm框架实现layui分页效果
2019/07/27 Javascript
Vue实现附件上传功能
2020/05/28 Javascript
解决vue的router组件component在import时不能使用变量问题
2020/07/26 Javascript
[01:07:20]DOTA2-DPC中国联赛 正赛 Dynasty vs XG BO3 第二场 2月2日
2021/03/11 DOTA
Python利用多进程将大量数据放入有限内存的教程
2015/04/01 Python
Selenium chrome配置代理Python版的方法
2018/11/29 Python
Python数据类型之Number数字操作实例详解
2019/05/08 Python
python绘制已知点的坐标的直线实例
2019/07/04 Python
python matplotlib:plt.scatter() 大小和颜色参数详解
2020/04/14 Python
CSS3 二级导航菜单的制作的示例
2018/04/02 HTML / CSS
英国最大的在线床超市:Bed Star
2019/01/24 全球购物
俄罗斯隐形眼镜和眼镜在线商店:Cronos
2020/06/02 全球购物
应届毕业生求职信
2013/11/30 职场文书
店长助理岗位职责
2013/12/13 职场文书
电子技术专业中专生的自我评价
2013/12/17 职场文书
会计试用期自我评价怎么写
2014/09/18 职场文书
2014党的群众路线教育实践活动总结材料
2014/10/31 职场文书
2015年事业单位办公室文员工作总结
2015/04/24 职场文书
市级三好生竞选稿
2015/11/21 职场文书
一篇文章弄懂Python关键字、标识符和变量
2021/07/15 Python
Java中CyclicBarrier和CountDownLatch的用法与区别
2021/08/23 Java/Android