koa框架(一) 认识koa

news2024/12/23 12:38:12

koa

  • ​koa是express原班人马打造的轻量、健壮、富有表现力的nodejs框架。目前koa有koa1和koa2两个版本;koa2依赖Node.js 7.6.0或者更高版本;koa不在内核方法中绑定任何中间件,它仅仅是一个轻量级的函数库,几乎所有功能都必须通过第三方插件来实现。

koa 的使用

基本服务

  • koa安装
    npm i koa
  • 一个简单的koa服务器
    const Koa = require('koa');
    const app = new Koa();
    
    app.use(async ctx => {
      ctx.body = 'Hello World';
    });
    app.listen(3000);
    
  • koa 利用中间件 控制“上游”,调用”下游“;
    • koa是包含一组中间件函数的对象;可以将app.use里的函数理解成中间件

      //这里的middleWare函数就是一个中间件
      let middleWare = async (ctx,next)=>{
          console.log("first middleWare");
          ctx.body = "hello world";
      }
      app.use(middleWare);
      
    • 通过next()将控制转交给另一个中间件;

    • 上述过程也可以通过"洋葱模型“来解释中间件执行顺序
      在这里插入图片描述

Application对象

  • application是koa的实例,简写app
  • app.use 将给定的中间件方法添加到此应用程序,分为同步和异步,异步:通过es7中的async和await来处理
  • app.listen设置服务器端口;
  • app.on 错误处理;

上下文context对象常用属性及方法

  • context 将node中的requestresponse封装到一个对象中,并提供一些新的api提供给用户进行操作;

  • ctx.app:应用程序实例引用,等同于app;

    • ctx.req: Node 的 request 对象.
    • ctx.res: Noderesponse` 对象.
    • ctx.request: koa中的Request对象;
    • ctx.response: koa中的response对象;
    • ctx.state:对象命名空间,通过中间件传递信息;
    • ctx.throw: 抛出错误;
  • requestresponse别名

    • koa会把ctx.requset上的属性直接挂载到ctx上如:

      • ctx.header
      • ctx.headers
      • ctx.method
      • ctx.method=
      • ctx.url
      • ctx.url=
        ……
    • 同样也会把ctx.response上的属性直接挂载到ctx上如:

      • ctx.body
      • ctx.body=
      • ctx.status
      • ctx.status=
        ….

      ctx.status 获取响应状态。默认情况下,response.status 设置为 404 而不是像 node 的 res.statusCode 那样默认为 200

koa常用中间件介绍

koa-router

  • 路由是引导匹配之意,是匹配url到相应处理程序的活动。
  • koa-router推荐使用RESTful架构API。Restful的全称是Representational State Transfer 即表现层转移。
    • RESTful是一种软件架构风格、设计风格,而不是标准,只是提供了一组设计原则和约束条件。基于这个风格设计可以更简洁,更有层次;
    • RESTful设计一般符合如下条件:
      • 程序或者应用的事物都应该被抽象为资源
      • 每个资源对应唯一的URI(uri是统一资源标识符)
      • 使用统一接口对资源进行操作
      • 对资源的各种操作不会改变资源标识
      • 所有操作都是无状态的
  • koa-router安装
    npm i koa-router -S
  • 基本使用
const KoaRouter = require('koa-router');
const router = new KoaRouter();
router.get('/login', ctx => {
    ctx.body = '登陆';
})
app.use(router.routes());

koa-views

  • Koa-views用于加载html模板文件;
  • 安装 koa-views
    npm i koa-views -S
    • 使用koa-view

koa-static

  • koa-static是用于加载静态资源的中间件,通过它可以加载css、js等静态资源;
  • 安装 koa-static
    npm i koa-static
  • 使用koa-static
  const static = require("koa-static");
 //加载静态文件的目录
  app.use(static(__dirname+"/static"),{
  		index:false,       // 默认为true  访问的文件为index.html  可以修改为别的文件名或者false
  		hidden:false,      // 是否同意传输隐藏文件
  		defer:true,		   // 如果为true,则在返回next()之后进行服务,从而允许后续中间件先进行响应
 }) 

koa-static-cache

  • 作用同koa-static,但是可以配置缓存策略
  • 安装 koa-static-cache
    npm i koa-static-cache
  • 使用koa-static-cache
const KoaStaticCache = require('koa-static-cache');
app.use(KoaStaticCache('./static', {
    prefix: '/public',  // URL前缀,默认是 '.'
    maxAge: 0,     // 缓存时间,单位毫秒,默认为0
    gzip: true,   // 启用gzip压缩传输,默认为true
    dynamic: true  
}));

koa-body

  • 安装 koa-body
    npm i koa-body
  • 使用koa-body
const koaBody = require('koa-body');
app.use(koaBody({
    multipart: true,
    // 处理上传的二进制文件
    formidable: {
        // 上传目录
        uploadDir: __dirname + '/public/upload',
        // 是否保留上传文件名后缀
        keepExtensions: true,
        onFileBegin(name, file) {
             // console.log('name, file', name, file);
            return false;
        }
    }
}));

demo

  • app.js
const Koa = require('koa');
const KoaRouter = require('koa-router');
const KoaStaticCache = require('koa-static-cache');
// 创建 server 对象
const server = new Koa();
// 创建静态文件代理服务
server.use( KoaStaticCache('./public', {
    prefix: '/public',
    gzip: true,
    dynamic: true
}) );
// 除了上面以 /public 开头的url,其它都会走下面router进行处理
// 创建动态资源(使用router来为动态资源做映射)
// 创建一个router对象
const router = new KoaRouter();
// 用 router 来注册各种需要用到的url资源处理函数
router.get('/', ctx => {
    ctx.body = 'Hello';
});
router.get('/getData', ctx => {
    // 不是合法的json格式
    // ctx.body = "{'name': 'koa'}";
    // 必须是双引号
    // ctx.set('Content-Type', 'application/json;charset=utf-8');
    // ctx.body = '{"name": "koa"}';
    // koa 框架内部帮助我们做了一些处理,如果你给body设置一个对象,那么koa内部会把这个对象转成json以后再发送,同时设置头信息application/json;charset=utf-8
    ctx.body = {name: 'koa'};
    // ctx.type = 'application/json;charset=utf-8';
    // 等同下面的代码
    // ctx.set('Content-Type', 'application/json;charset=utf-8');
});
router.post('/attachment', upload('/static/attachment'), async ctx => {
    console.log(ctx.files);
    ctx.body = '上传成功';
});
// 把router对象的routes中间件注册到Koa中
server.use(router.routes());
// 启动服务,并监听指定的端口
server.listen(8081, () => {
    console.log('服务启动成功,http://localhost:8081');
});

function upload(dir) {
    return koaBody({
        // 开启二进制content-type类型的处理
        multipart: true,
        formidable: {
            uploadDir: __dirname + dir,
            keepExtensions: true,
            onFileBegin(name, file) {
                // console.log('name, file', name, file);
                return false;
            }
        }
    });
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/21213.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[附源码]java毕业设计网上点餐系统

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

干货分享丨第五届“大数据安全与隐私计算”学术会议

开放隐私计算 开放隐私计算 开放隐私计算OpenMPC是国内第一个且影响力最大的隐私计算开放社区。社区秉承开放共享的精神,专注于隐私计算行业的研究与布道。社区致力于隐私计算技术的传播,愿成为中国 “隐私计算最后一公里的服务区”。 177篇原创内容 …

网页设计大作业模板-网页设计大作业(文房四宝 5页)-实训素材

⛵ 源码获取 文末联系 ✈ Web前端开发技术 描述 网页设计题材,DIVCSS 布局制作,HTMLCSS网页设计期末课程大作业 | 茶文化网站 | 中华传统文化题材 | 京剧文化水墨风书画 | 中国民间年画文化艺术网站 | 等网站的设计与制作| HTML期末大学生网页设计作业,W…

通过STM32F103C8T6配置完成基于SPI协议的0.96OLED屏显

文章目录前言一、SPI协议1、应用2、组成二、OLED屏显和汉字点阵编码原理1、汉字点阵编码原理2、OLED屏显三、OLED模块四、显示自己的学号和姓名五、显示温湿度&滑动显示长字符六、总结七、参考资料前言 硬件:stm32f103c8t6 核心板软件:keil5 mdk软件…

混沌引力搜索算法(CGSA)解决三个机械工程设计问题(Matlab代码实现)

👨‍🎓个人主页:研学社的博客 💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜…

_linux 进程间通信(匿名管道)

文章目录1. 匿名管道2. 利用通过匿名管道实现进程间通信2.1 实现思路2.2 父子进程实现通信的简单代码2.3 结果展示如下3. 总结管道特点4. 扩展(好玩的--简单内存池)思路:代码:1. 匿名管道 查看手册(man): 翻译 #incl…

[附源码]计算机毕业设计JAVA基于JSP技术的新电商助农平台

[附源码]计算机毕业设计JAVA基于JSP技术的新电商助农平台 项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: …

Amine-PEG-Azide,NH2-PEG-N3,胺-PEG-叠氮PEG试剂供应

1、名称 英文:Amine-PEG-Azide,NH2-PEG-N3 中文:胺-聚二乙醇-叠氮 2、CAS编号:N/A 3、所属分类:DSPE PEG Azide PEG 4、分子量:可定制,NH2-PEG-N3 2000、胺-聚二乙醇-叠氮 10000、NH2-PEG-…

从零开始做一款Unity3D游戏<一>——亲自上手使用Unity

游戏设计入门 游戏设计文档 Hero Born游戏的单页文档 构建关卡 创建基本图形 在三维中思考 材质 白盒环境 光照基础 创建光源 Light组件的属性 在Unity中制作动画 创建动画片段 记录关键帧 曲线与切线 粒子系统 总结 本文主要来自<<C#实践入门>>哈…

【单片机】独立看门狗IWDG初始化

目录 看门狗简介&#xff1a; 初始化例子&#xff1a; 看门狗使能&#xff1a; 写保护&#xff1a; 看门狗重载&#xff1a; 看门狗复位时间计算&#xff1a;基本上看stm中文手册对照框图就很明确 看门狗简介&#xff1a; 此器件具有两个嵌入式看门狗外设&#xff0c;具有…

3-4数据链路层-局域网

文章目录一.基本概念1.网络拓扑2.传输介质3.介质访问控制方法4.局域网的分类5.逻辑链路控制&#xff08;LLC&#xff09;子层与媒体接入控制&#xff08;MAC&#xff09;子层二.以太网&#xff08;一&#xff09;以太网的传输介质与网卡1.传输介质2.网卡&#xff08;二&#xf…

[附源码]计算机毕业设计JAVA基于JSP学生信息管理系统

[附源码]计算机毕业设计JAVA基于JSP学生信息管理系统 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM …

工具及方法 - 编辑二进制文件(使用VSCode和Notepad++的插件Hex Editor)

Visual Studio Code 在VSCode里安装插件&#xff0c;可以实现很多功能。 打开VSCode&#xff0c;在菜单里选择&#xff0c; View->Extensions&#xff0c;就会出现扩展插件的查找页面。 输入想要查找的插件名称&#xff0c;搜索&#xff0c;然后点击安装。 比如要用VSCode…

高性能零售IT系统的建设06-当应对大量HTTP请求时兼顾性能、处理速度的架构设计

前言 这个系列不像我的那些个“保姆式”教程&#xff0c;那些保姆式教程我一周最多可以写8篇&#xff0c;因为太简单了。充其量花的时间就是用“看漫画”的方式去组织我的截图和尽量少文字多Sample。 而高性能系统建设系列这一块不仅仅只有代码&#xff0c;相反它甚至不会多写…

力扣(LeetCode)25. K 个一组翻转链表(C++)

模拟 前置知识 : 反转链表、两两交换链表中的节点 。 LeetCode 有相应题目&#xff0c;可以先做。 设置哑结点 &#xff0c; 便于操作头结点。 翻转至少要 kkk 个结点 &#xff0c; 先检查剩余结点够不够 kkk 个。 不够 kkk 个就翻转完成了。 翻转分为组内翻转和首尾变向两步…

查找xml文件

一 前言 相比xml.dom.minidom&#xff0c;lxml.etree具有高效的查找方法&#xff0c;更方便&#xff0c;直接&#xff1b; 二、知识点&#xff1a;查找感兴趣的元素 举例一&#xff1a;递归遍历其下的所有子树&#xff08;包括子级&#xff0c;子级的子级&#xff0c;等等 …

nero platinum刻录光盘简要教程(文章末尾有教程链接)

nero platinum suit 介绍 使用nero express可以完成多数情况下的光盘应用。在nero platinum suit中单击nero express&#xff0c;这时可以看到nero express的工作界面&#xff0c;在这里面可以刻录数据光盘&#xff0c;可以刻录音乐光盘&#xff0c;可以刻录视频光盘&#xff…

SpringMVC集成静态资源

集成静态资源 静态资源&jsp是被谁处理的 tomcat是一个servlet容器&#xff0c;servlet容器中通常有servlet来处理各种请求&#xff0c;那么当访问静态资源或者jsp的时候&#xff0c;当然也是有servlet来处理这些请求的&#xff0c;但是并未在web.xml中配置哪个servlet来处…

SpringBoot+Vue项目小区疫苗接种管理系统的设计与实现

文末获取源码 开发语言&#xff1a;Java 使用框架&#xff1a;spring boot 前端技术&#xff1a;JavaScript、Vue 、css3 开发工具&#xff1a;IDEA/MyEclipse/Eclipse、Visual Studio Code 数据库&#xff1a;MySQL 5.7/8.0 数据库管理工具&#xff1a;phpstudy/Navicat JDK版…

MySQL数据库JDBC编程

目录 前言&#xff1a; 项目中导入驱动包 插入记录 创建数据源 连接数据库 构造sql语句 执行sql语句 释放资源 整体代码展示 查看数据 代码展示 小结&#xff1a; 前言&#xff1a; MySQL为Java提供了驱动包。通过Java程序实现的客户端&#xff0c;可以通过这个驱动…