Koa帮我们做了什么
整理web渲染思路,与KOA作比较
1.开启服务器并监听端口,注册监听事件
// 原生
let http = require('http')
const server = http.createServer((req, res) => {
// res.setHeader('Content-Type', 'text/html')
// res.end('ok')
});
server.listen(port)//port为端口
// Koa 将监听事件request移出构造,设计到中间件内
let Koa = require('koa')
let app = new Koa ()
app.listen(port)
2.请求信息分析url模块
1.路径url.parse(req.url) 请求路径的获取以及请求类型的获取(这里被Koa处理并包装成一个request对象)
// 原生
const server = http.createServer((req, res) => {
let url = url.parse(req.url)
let method = req.method
});
// Koa 将信息封装到request对象上,并可以通过别名简化访问
app.use(async ctx => {
let url = ctx.url
let method = ctx.method
})
2.参数接受querystring,以及POST方法参数获取(监听res的data事件,在end方法中获取)(这里设计成了一个koa-bodyparse中间件)
//get
// 原生
const server = http.createServer((req, res) => {
let url = url.parse(req.url)
let query = querystring(url.query)
});
// Koa 将信息封装到request对象上,并可以通过别名简化访问
app.use(async ctx => {
let query = ctx.query
})
//post
// 原生
const server = http.createServer((req, res) => {
let content
req.on('data', chunk => {
content+=chunk
})
req.on('end', () => {
let query = querystring.parse(content)
console.log(query)
})
});
// Koa 将过程封装到中间件去
let bodyParser = require('koa-bodyparser')
app.use(boodyParser())
app.use(async ctx => {
let postQuery = querystring.parse(ctx.request.body);
})
3.静态资源与动态资源(返回头信息已经被Koa处理)
静态资源 设定静态资源路径,对静态资源路径结合fs模块返回(中间件)
// 原生
//通过fs访问静态资源,需要手动设置内容类型以及状态码
function staticSend(filename, headers={'Content-Type': 'text/html;charset=utf-8'}, statusCode=200) {
res.writeHead(statusCode, http.STATUS_CODES[statusCode], headers);
content = fs.readFileSync(filename);
res.end(content);
}
const server = http.createServer((req, res) => {
let url = url.parse(req.url)
staticSend(`${__dirname}/${url}`)
});
// Koa 通过koa-static-cache中间件可以设置静态资源访问规则,只需定义访问路径即可
const koaStaticCache = require('koa-static-cache')
app.use( koaStaticCache( __dirname + '/static', {
prefix: '/public',
} ) )
动态资源 设定对应路径的请求返回 路由处理
// 原生
// 根据访问路径case然后处理对应路径返回结果
// Koa
const Router = require('koa-router');
const router = new Router();
router.get('/list', async (ctx, next) => {
ctx.body = await ctx.render('list.html', {
users
});
})
app.use( router.routes() );
Koa核心:这个框架有点思想和webpack类似,编写文件->loader/plugins->最终文件,而Koa就是,请求->中间件->返回
它把请求与返回优雅地处理好了,我们只需要关注中间部分逻辑,即中间件
Koa帮我们做了什么的更多相关文章
- (旧)子数涵数·C语言——让C帮你做计算
之前,我们学过了我们的第一个C程序--hello World.现在开始进一步学习,想一想如何让C帮你做计算. 我们先来看代码(我没有新建,还是用之前的hello world.cpp): 好,因为之前在 ...
- javaCV开发详解之技术杂烩:javaCV能帮我们做什么?能实现什么功能?ffmpeg和openCV能实现功能,javaCV如何做到更快、更简单的实现相应的功能?等等一堆实用话题
前言: 该篇文章旨在帮助刚接触javaCV的盆友系统的认识音视频.javaCV.图像处理相关的体系知识和一些实用的知识. 序: javaCV早期因为内置了openCV库,所以常用来做图像识别应用,现在 ...
- spring是什么,Spring能帮我们做什么
1. spring是什么? Spring是一个开源的轻量级Java SE(Java 标准版本)/Java EE(Java 企业版本)开发应用框架,其目的是用于简化企业级应用程序开发.应用程序是由一组相 ...
- adb工具包究竟能帮我们做什么?
adb工具包主要作用于什么呢?应该有很多用户都不了解adb,那就一起来了解一下吧!adb的全称为Android Debug Bridge,就是起到调试桥的作用. 借助adb工具,我们可以管理设备或手机 ...
- QT就是别人好心帮你做一些枯燥,并且很重复的代码编写工作,让你更好的把精力投入到你界面的逻辑和功能的实现的功能库(否则写了上万行代码了,才写出个BUG一大堆的毛坯)
好了,现在开始记录我学习QT的学习历程 . 本人也不是计算机专业出来的,自学了一点,但还是不好找工作,于是参加了培训,虽然感觉没多学到什么 编程的学习生涯就是不断的看别人的源码,然后自己参考着写写自己 ...
- 我用Python帮朋友做了张猪肉数据分析图,结果。。。
却发现他是这么拿我当兄弟的 事情的经过是这样的: 我开开心心的去一家烧饼店吃饭 . 抬头一看,二师兄又涨价了 叹了口气,再这么下去真的要吃不起夹肉的烧饼了 点了两个烧饼一碗馄饨 快吃完的时候, ...
- 帮我做个APP,给你20万,做不做?
一.为什么要写这篇文章 前段时间,有个辞职 创业的同事(做法务的) 问我 开发一个 新闻类的APP要多少钱,产品.UI.接口.后台管理页 他们啥都没有,想全部外包. 我 并没有在外包公司做过,也没 ...
- Sql优化器究竟帮你做了哪些工作
https://my.oschina.net/u/1859679?tab=newest&catalogId=597012 上一篇,我们介绍了<DB——数据的读取和存储方式>,这篇聊 ...
- Sql优化器究竟帮你做了哪些工作?
关系型数据库的一大优势之一,用户无需关心数据的访问方式,因为这些优化器都帮我们处理好了,但sql查询优化的时候,我不得不要对此进行关注,因为这牵扯到查询性能问题. 有经验的程序员都会对一些sql优化了 ...
随机推荐
- 另一种缓存,Spring Boot 整合 Ehcache
用惯了 Redis ,很多人已经忘记了还有另一个缓存方案 Ehcache ,是的,在 Redis 一统江湖的时代,Ehcache 渐渐有点没落了,不过,我们还是有必要了解下 Ehcache ,在有的场 ...
- Java学习:IO流
IO流 1.IO流 用于处理设备上的数据. 设备:硬盘,内存,键盘录入. 2. IO有具体的分类: 根据处理的数据类型不同:字节流和字符流. 根据流向不同:输入流和输出流. 字符流的由来: 因为文件编 ...
- vue-如何实现带参数跳转页面
[前后端分离项目之vue框架经验总结] 文/朱季谦 在vue框架的前端页面上,若要实现页面之间的带参数跳转,可参考以下实现过程: 例如,点击截图中的“查看试卷”,可实现带参跳转到相应的试卷页面,该功能 ...
- 2019-11-29-C#-反射调用私有事件
原文:2019-11-29-C#-反射调用私有事件 title author date CreateTime categories C# 反射调用私有事件 lindexi 2019-11-29 08: ...
- 关于“关于C#装箱的疑问”帖子的个人看法 (原发布csdn 2017年10月07日 10:21:10)
前言 昨天晚上闲着无事,就上csdn逛了一下,突然发现一个帖子很有意思,就点进去看了一下. 问题很精辟 int a = 1; object b=a; object c = b; c = 2; 为什么b ...
- 关于CSS特性和选择器
1层叠 样式冲突的遵循就近原则, 2继承 子代会继承父代的某些属性,例如字体大小,字体颜色 3优先级 !important 权重最高 通配符 * 和 继承的属性 权重为 0 0 0 0 行内样式权 ...
- 使用order by和group by的分析
mysql 写sql的顺序: select -> from-> where->group by->having->order by. 但mysql的解析 ...
- Java常用框架和软件
- 2019-09-16 curl简单操作
1.get请求 (使用file_get_contents()函数也可以实现get请求) //http_build_query() 构造一个url字符串 function http_get($url) ...
- Centos7下安装redis并能使得外网访问
一.安装脚本 #!/bin/bash #FileName: install_redis_centos7.sh #Date: #Author: LiLe #Contact: @qq.com #Versi ...