koalified什么意思 koa

express和koa的区别 express和koa从整体上来看,koa是比express更加轻量,他没有内置的各种中间件的支持,更集中于请求处理 。当然在express 4.0以后,也移除了一批中间件支持,向轻量化进发 。这一点上差别其实不是特别大了 。
最大的差别是中间件和回调的处理逻辑 。express采用的是callback,koa采用的是async,这样在执行上express的callback中就天然不支持异步的处理,在express中处理异步可能不是你想要的执行顺序 。在这里,就有了koa的经典:洋葱模型 。
除此之外,koa在响应上添加了上下文的概念,使用ctx存储各种响应信息,避免直接操作res 。ctx能更好的帮助我们在多层级处理中传递信息,例如ctx.body可以多层级进行组合返回数据 。
express 3 - 4 之后,移除了一大批中间件,其中和我们关系比较大的是bodyParser、compress、cookieSession、cookieParser、static、directory等 。
除此之外,4改变了路由注册的方式(增量式),增加了app.route、router = express.Router()的方式,中间件的app.use也支持path的注册 。详见 Moving to Express 4。
传送门
express和koa的区别

koalified什么意思 koa

文章插图
Koa 学习总结Koa是基于Node.js的下一代web框架,由Express团队打造,特点:优雅、简洁、灵活、体积小 。几乎所有功能都需要通过中间件实现 。
即便没有给ctx.body 设置响应数据,或访问不存在的路由,页面也会显示Not Found,这是koa底层做了处理,不像原生Node或Express一样页面会一直处于响应状态 。
Koa将Node的request 和 response对象都封装到了context中,每次请求都会创建一个ctx,并且在中间件中作为接收器使用 。
【koalified什么意思 koa】 以下是刚才访问时的ctx对象
即便使用ctx.res.write()也不会得到预期结果,比如:ctx.res.write('hello'),结果是hellook,会把message的值拼接上 。
有关cookie和session单独介绍用法 。
Koa中的路由和Express不同,Express是把路由集成在Express中,Koa则需要通过kao-router模块使用 。
Koa最大的特色和最优的设计就是中间件,就是在匹配路由之前和匹配路由之后执行函数 。
使用app.use()加载中间件 。每个中间件接收两个参数,ctx对象和next函数,通过调用next将执行权交给下一个中间件 。
中间件分为:
对于诸如js、css、img等静态资源采用koa-static中间件处理 。
比如静态目录为static:
在模板中即可访问:
koa生态的模板引擎挺多的,比如ejs、art-template等 。
使用方式和ejs一样 。
性能上相比,art-template比ejs快很多,开发中用的最多的还是art-template 。
http是无状态、无连接的 。不会对之前发生过的请求和相应状态进行管理 。也就是说,无法根据之前的状态进行本次的请求处理 。
比如访问淘宝首页并登录账号后,当再打开淘宝其他页面时,因为每一次的访问都是独立的,服务器并不知道你已经登录,所以还是不能下单或者加购物车之类的操作 。
cookie是客户端第一次访问服务器的时候,服务器在下行HTTP报文时通过响应头的 set-cookie 字段给浏览器分配的一个具有特殊标识的文本信息,此后当客户端再次访问同一域名时,便会将该字段通过请求头携带到服务器 。注意: 第一次访问服务器是不可能携带cookie的 。
缺陷: 1、cookie的数据存放在客户端,不安全,容易被(CSRF)跨站请求伪造 。攻击者可以借助受害者的 Cookie 骗取服务器的信任,可以在受害者毫不知情的情况下以受害者名义伪造请求发送给受攻击服务器,从而在并未授权的情况下执行在权限保护之下的操作 。2、单个cookie保存的数据不能超过4K,很多浏览器都限制一个站点最多保存20个cookie 。
通过 options 获取 cookie name:
通过 options 设置 cookie name 的 value:
通过buffer转成base64存进去,取出来是再转回中文 。
session是另一种记录客户状态的机制,不同的是cookie保存在客户端浏览器中,而session保存在服务器上 。
前面说过,cookie 是存放在客户端,不是很安全,用户可以自己手动把cookie种在客户端以欺骗服务器 。而session是存储在服务端的,所以对于较重要的数据存储在session 。
缺点: session会在一定时间内保存在服务器上 。当访问增多,会比较占用你服务器的性能 。
当浏览器第一次请求服务器时,服务器端会创建一个session对象,生成一个类似于key-value的键值对,然后将key(cookie)下发到客户端,当客户端再访问时,携带key(cookie),找到对应的session(value) 。生产中用户的信息都保存在session中 。

秒懂生活扩展阅读