koa模块

koa-route 路由 route.get("路径",路由函数)

koa-static 静态资源加载     const serve(路径)

koa-compose  中间件合成模块

koa-body   提取表单post请求键值对,处理上传文件

上下文context的response和request

ctx.response.body   //返回的主体内容

ctx.response.redirect //重定向

ctx.response.type   //返回的MIME类型

ctx.response.path  //获取用户请求的路径

ctx.response.status  //返回的状态码

ctx.request.accepts //请求的mime类型

ctx.request.method //请求的方法

ctx.request.url         //请求的url

ctx.request.body //请求的body

中间件(middleware)

Logger 打印日志 //不需要引入任何,直接输入console.log,在命令框就会打印出来

中间件功能可以拆分成一个独立函数比如叫logger,参数(ctx,next) 然后app.use(logger),用来加载中间件

基本上,Koa 所有的功能都是通过中间件实现的,前面例子里面的main也是中间件。

每个中间件默认接受两个参数,第一个参数是 Context 对象,第二个参数是next函数。

只要调用next函数,就可以把执行权转交给下一个中间件。

中间件栈

多个中间件会形成一个栈结构(middle stack),以"先进后出"(first-in-last-out)的顺序执行。

  1. 最外层的中间件首先执行。
  2. 调用next函数,把执行权交给下一个中间件。
  3. ...
  4. 最内层的中间件最后执行。
  5. 执行结束后,把执行权交回上一层的中间件。
  6. ...
  7. 最外层的中间件收回执行权之后,执行next函数后面的代码。

例如:有多个中间件,每个中间件分别写了next()函数,则每个中间件会分别先执行next()函数之前的打印,然后再分别执行next()之后的打印,如果不写next()函数,那么执行权就不会传递下去,则只打印第一个中间件的内容。

const one = (ctx, next) => {
console.log('>> one');
next();
console.log('<< one');
} const two = (ctx, next) => {
console.log('>> two');
next();
console.log('<< two');
} const three = (ctx, next) => {
console.log('>> three');
next();
console.log('<< three');
} app.use(one);
app.use(two);
app.use(three);
>> one
>> two
>> three
<< three
<< two
<< one
const Koa = require('koa');
const app = new Koa(); const one = (ctx, next) => {
console.log('>> one');
// next();
console.log('<< one');
} const two = (ctx, next) => {
console.log('>> two');
// next();
console.log('<< two');
} const three = (ctx, next) => {
console.log('>> three');
// next();
console.log('<< three');
} app.use(one);
app.use(two);
app.use(three); app.listen(3000);
>>one
<<one
const Koa = require('koa');
const app = new Koa(); const one = (ctx, next) => {
console.log('>> one');
next();
console.log('<< one');
} const two = (ctx, next) => {
console.log('>> two');
// next();
console.log('<< two');
} const three = (ctx, next) => {
console.log('>> three');
next();
console.log('<< three');
} app.use(one);
app.use(two);
app.use(three); app.listen(3000);
>>one
>>two
<<two
<<one

异步中间件

比如读取数据库等的异步操作,使用ES8 的 async和await

中间件的合成

koa-compose模块可以将多个中间件合成为一个

错误处理

ctx.throw()方法   参数为错误的http状态码

当直接用ctx.throw()抛出错误之后,则不能在定义返回的页面显示内容,所以可以先设置返回的状态码为相应的状态码,然后定义返回页面的内容

const main = ctx => {
ctx.response.status = 404;
ctx.response.body = 'Page Not Found';
};

处理错误的中间件

使用try..catch捕获

try{

  await next()

}catch{

  错误处理

}

error 事件的监听

运行过程中一旦出错,Koa 会触发一个error事件。监听这个事件,也可以处理错误。

释放 error 事件

需要注意的是,如果错误被try...catch捕获,就不会触发error事件。这时,必须调用ctx.app.emit(),手动释放error事件,才能让监听函数生效。

const handler = async (ctx, next) => {
try {
await next();
} catch (err) {
ctx.response.status = err.statusCode || err.status || 500;
ctx.response.type = 'html';
ctx.response.body = '<p>Something wrong, please contact administrator.</p>';
ctx.app.emit('error', err, ctx);
}
}; const main = ctx => {
ctx.throw(500);
}; app.on('error', function(err) {
console.log('logging error ', err.message);
console.log(err);
});

Cookies

ctx.cookies用来读写 Cookie。

表单

Web 应用离不开处理表单。本质上,表单就是 POST 方法发送到服务器的键值对。koa-body模块可以用来从 POST 请求的数据体里面提取键值对。

文件上传

参考链接:阮一峰老师的文章

koa2入门学习的更多相关文章

  1. vue入门学习(基础篇)

    vue入门学习总结: vue的一个组件包括三部分:template.style.script. vue的数据在data中定义使用. 数据渲染指令:v-text.v-html.{{}}. 隐藏未编译的标 ...

  2. Hadoop入门学习笔记---part4

    紧接着<Hadoop入门学习笔记---part3>中的继续了解如何用java在程序中操作HDFS. 众所周知,对文件的操作无非是创建,查看,下载,删除.下面我们就开始应用java程序进行操 ...

  3. Hadoop入门学习笔记---part3

    2015年元旦,好好学习,天天向上.良好的开端是成功的一半,任何学习都不能中断,只有坚持才会出结果.继续学习Hadoop.冰冻三尺,非一日之寒! 经过Hadoop的伪分布集群环境的搭建,基本对Hado ...

  4. PyQt4入门学习笔记(三)

    # PyQt4入门学习笔记(三) PyQt4内的布局 布局方式是我们控制我们的GUI页面内各个控件的排放位置的.我们可以通过两种基本方式来控制: 1.绝对位置 2.layout类 绝对位置 这种方式要 ...

  5. PyQt4入门学习笔记(一)

    PyQt4入门学习笔记(一) 一直没有找到什么好的pyqt4的教程,偶然在google上搜到一篇不错的入门文档,翻译过来,留以后再复习. 原始链接如下: http://zetcode.com/gui/ ...

  6. Hadoop入门学习笔记---part2

    在<Hadoop入门学习笔记---part1>中感觉自己虽然总结的比较详细,但是始终感觉有点凌乱.不够系统化,不够简洁.经过自己的推敲和总结,现在在此处概括性的总结一下,认为在准备搭建ha ...

  7. Retrofit 入门学习

    Retrofit 入门学习官方RetrofitAPI 官方的一个例子 public interface GitHubService { @GET("users/{user}/repos&qu ...

  8. MyBatis入门学习教程-使用MyBatis对表执行CRUD操作

    上一篇MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对use ...

  9. opengl入门学习

    OpenGL入门学习 说起编程作图,大概还有很多人想起TC的#include <graphics.h>吧? 但是各位是否想过,那些画面绚丽的PC游戏是如何编写出来的?就靠TC那可怜的640 ...

随机推荐

  1. pandas的学习总结

    pandas的学习总结 作者:csj更新时间:2017.12.31 email:59888745@qq.com 说明:因内容较多,会不断更新 xxx学习总结: 回主目录:2017 年学习记录和总结 1 ...

  2. 机器学习集成算法--- 朴素贝叶斯,k-近邻算法,决策树,支持向量机(SVM),Logistic回归

    朴素贝叶斯: 是使用概率论来分类的算法.其中朴素:各特征条件独立:贝叶斯:根据贝叶斯定理.这里,只要分别估计出,特征 Χi 在每一类的条件概率就可以了.类别 y 的先验概率可以通过训练集算出 k-近邻 ...

  3. JavaScript 里面的整数 位 操作

    JavaScript 整数位操作. 与 操作符 & val num1 = 10; val num2 = 11; val num3 = num1 & num2; // num3 == 1 ...

  4. 线程的几种状态转换<转>

    线程在一定条件下,状态会发生变化.线程一共有以下几种状态: 1.新建状态(New):新创建了一个线程对象. 2.就绪状态(Runnable):线程对象创建后,其他线程调用了该对象的start()方法. ...

  5. Python基础知识小结

    1. 关于函数传参 def func(n, *args, **kwargs): print n print args print kwargs if __name__ == '__main__': # ...

  6. 纯css 404

    <section class="center"> <article> <h1 class="header"> 404< ...

  7. 在CentOS 6.4中支持exfat格式的U盘

    CentOS系列一直没有默认支持使用exfat格式的大容量U盘. 可以通过添加fuse-exfat模块来支持.根据网上资料,整理如下: 1.下载fuse-exfat支持软件: exfat支持是通过fu ...

  8. 一款基于jquery和css3的头像恶搞特效

    今天给大家分享一款基于jquery和css3的头像恶搞特效.这款实例中,一个头像在画面中跳舞,头像还有可爱的帽子,单击下面的按钮可以为头像切换不同的帽子.效果图如下: 在线预览   源码下载 实现的代 ...

  9. Intel edison 智能硬件开发指南 基于YoctoProject

    首先简单的介绍一下edison的板子: edison 芯片 22nm工艺,quark双核SoC,采用atom架构,针对小型智能设备  X86架构 相当于一台“奔腾级电脑” 低功耗,小体积,自带wifi ...

  10. 关于Unity中的刚体和碰撞器的相关用法(二)

    在关于Unity中的刚体和碰撞器的相关用法(一)的基础上 有一个plane平面,一个ball球体,都挂了碰撞器,ball挂了刚体Rigidbody,写了一个脚本ball挂载在球体上,球体从空中落下装机 ...