快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

node中间件都有哪些

node中间件有:1、koa-bodyparser;2、koa-body;3、静态资源管理器koa-static;4、cors;5、koa-cors;6、koa-cors2设置请求头等等。

创新互联公司是一家集网站建设,东山企业网站建设,东山品牌网站建设,网站定制,东山网站建设报价,网络营销,网络优化,东山网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。

本文操作环境:Windows7系统,nodejs10.16.2版,Dell G3电脑。

node中间件都有哪些?

node中间件类型:

node中间件就是封装在程序中处理http请求的功能。node中间件是在管道中执行。中间件位于客户机/ 服务器的操作系统之上,管理计算机资源和网络通讯。

中间件为主要的逻辑业务所服务,可分为:应用级中间件、路由级中间件、内置中间件、第三方中间件、错误级中间件。

node常用的中间件:

在node的学习过程中积累了许多好用的中间件。这些中间件大部分要个koa配合使用

1、koa-bodyparser

这个插件使用来解析前端post请求带来的参数的

//入口文件const bodyParser = require('koa-bodyparser');app.use(bodyParser({//设置可以接收的数据类型 enableTypes:['json', 'form', 'text']}))async function (ctx) { console.log(ctx.request.body) ctx.req.on('data',(data) => { console.log(JSON.parse(data),'文件') })}

在没有引入koa-bodyparser的情况下只能通过ctx.req.on('data',callback)来获取参数

而引入中间件后只要ctx.request.body就可以获取到参数。相比第一种便利很多。

2、koa-body

这个插件是用来获取请求中上传的文件和文件信息比如图片过zip文件

const koaBody = require('koa-body')app.use(koaBody({ multipart: true, formidable: { maxFileSize: 20 * 1024 * 1024 // 设置上传文件大小限制,默认2M } }))

在请求的处理中就可以直接通过ctx.request.files就能获取到所有上传的文件的信息。

注意!!!用了koa-body就不要在使用koa-bodyparser会冲突导致前端的post请求返回的status码为canceled

3、静态资源管理器koa-static

在本地测试的时候我上传了一张图片,然后将图片地址打印后是一长串的c://.../name/.png,这样虽然在本地能够访问但是如果放到服务器上就行不通了!

通过引入koa-static可以将静态文件地址指定到项目路径上的某个文件夹然后通过koa监听的端口直接http://192.168.0.177:3030/name.png就能访问图片了

const koaStatic = require('koa-static')app.use(koaStatic('./public'))//括号中是设置的静态文件路径

4、cors、koa-cors、koa-cors2设置请求头

这几个中间件基本我都是用来配置跨域和请求头的信息

const cors = require('koa2-cors') app.use(cors({ exposeHeaders: ['multipart/form-data','application/x-www-form-urlencoded']}))

可以自己设置参数也可以不设置参数直接app.use(cors())就可以跨域。

这里说到跨域就顺便提一提原生node跨域的设置方法(同样可以设置请求头的各种配置)

app.use(async (ctx, next) => { ctx.set('Access-Control-Allow-Origin', ctx.headers.origin)//'*'有可能会问题 ctx.set('Access-Control-Allow-Credentials', 'true') ctx.set('Access-Control-Allow-Headers', 'Origin ,multipart/form-data, X-Requested-With, Content-Type, Accept') await next()})

后续要是有遇到哪些好用的中间件再来记录!!!

推荐学习:《node.js视频教程》


本文名称:node中间件都有哪些
新闻来源:http://6mz.cn/article/cjgjdg.html

其他资讯