因为Koa2已经在蓬勃发展中,且Express不太符合自己的需求。 所以基于Koa2订制了一套适合自己的模板。
- 渲染模板(EJS)
- 发送静态文件,如HTML文件。
- 编写自定义路由与Restful Api,默认支持CORS跨域
- 读取post数据
- 纯ES6/7编写,使用koa2的Async/Await,避免回调地狱
- 自定义错误,可附加错误信息
- 默认支持gzip,减少传输体积,加快传输速度
- 开箱即用,无需折腾
直接运行run.js即可
因为Koa2使用babel和ES7的Async/Await,所以需要使用babel转译启动
node run.js
检测到文件变动,会自动重启服务器
npm i
npm run dev
npm i pm2 -g
npm run pm2
PORT=8000 npm run dev
PORT=8000 npm run pm2
把8000替换成任何你想使用的端口即可
推荐使用VeryNginx实现。
具体配置(需要先安装VeryNginx): 先配置一个 Matcher : host=app.xxxx.com ,用来提取出来所有访问 host 为 app.xxxx.com 的请求 然后配置 Proxy Pass 把这个请求转发到 127.0.0.1:3000 就可以了
需要具有ES6基础。
// router/index.js
router
.get('/', async (ctx, next) => {
// 模板渲染,第一个参数为模板名称
// 模板放置于views文件夹中
await ctx.render('index', { title: 'Koa-Easy' })
})
// router/index.js
router
.get('/index', async (ctx, next) => {
// 发送静态文件
await ctx.send(ctx, 'index.html', { root: 'static' })
})
直接将ctx.body设置为json格式即可
// router/test.js
router
.get('/json', (ctx, next) => {
ctx.body = { test: 'json' }
})
ctx.request.body就是post发送的数据
// router/test.js
router
.post('/post', (ctx, next) => {
ctx.body = ctx.request.body
})
按照router文件夹中范例编写,并在app.js中添加即可。
添加了自定义错误,调用时使用ctx.Err。
// router/api/user.js
// 一般错误处理,message和status为必须选项,否则为默认的Error与500。status为http状态码
throw new ctx.Err({ message: '用户已存在', status: 400})
// 用户收到的信息: {"message": "用户已存在","status": 400"}
// 附加额外错误信息,写在第二个对象里就行
throw new ctx.Err({ message: '用户已存在', status: 400}, {'error': true})
// 用户收到的信息: {"message": "用户已存在","status": 400","error": true}