node.js中Express框架路由,中间件

简介: node.js中Express框架路由,中间件

框架

安装express

npm install express --save
const express =require('express')
const app=express()
app.use('/',function(res,req,next){
    console.log('hh');
    //中间件有一个next()函数,如果不调用next函数,请求就在这个中间件中终止了
    next()
})
app.get('url地址',function(req,res){
  //用res.send()方法向客户端发送----可以是对象,字符串等
  res.send('hahahha')
})
//启动
app.listen(810,function(){
    console.log('http://127.0.0.1:810');
})

中间件

  • 除错误级别中间件要放在所有路由之后,其他中间件必须放在所有路由之前
  • 客户端发过来的请求,可以连续多个中间件进行处理
  • 执行完中间件业务代码后,要调用next(),后面不要写额外代码
  • 连续调用多个中间件时,多个中间件之间,共享req,res对象

中间件函数:

function(req,res,next){
  console.log('sdf')
  //将流转关系转交给下一个中间件或者路由
  next()
}

如要在路由处理链上插上中间件,express的use方法:

app.use([path],function(){})

其中path无参数时,默认路径为’/‘

全局生效的中间件:客户端发送任何请求到达服务器都会触发的中间件(使用app.use()方法),若想在多个路由中使用同种属性,可以将其写在中间件中,用req对象自定义属性,传给后面所要共享的路由

app.use(function(req,res,next){
    const time =Date.now()
    //为req对象,挂载自定义属性,从而把时间共享给后面
    req.startTime=time
    //把流转关系,转交给下一个中间件或路由
    next()
})

局部生效中间件:不使用app.use()方法,直接在路由中添加局部中间件函数

const mw =function(req,res,next{
  console.log('oooooo')
})
app.get('/',mw,function(req,res){
  res.send('okokok')
})

app.get([path],‘中间件函数名称’,function(req,res){})

内置中间件:客户端发送请求体数据,解析数据

  • express.static :静态托管资源中间件
app.use('/demo',express.static('demo'))
  • 解析json请求体数据
app.use(express.json())
  • 解析json请求体数据
app.use(express.json())

第三方中间件(body-parser):

1.运行npm install body-parser

2.使用require导入中间件

3.调用app.use()注册并使用中间件

//导入解析表单数据的中间件body-parser
const parser = require('body-parser')
//使用app.use()注册中间件
app.use(parser.urlencoded({entended:false}))
//发送请求
app.post('/',function(req,res)){
  console.log(req.body)
  res.send('sleep')
}

自定义中间件:客户端发送的请求可以显示出来

const qs = require('querystring')
//解析表单数据中间件
app.use(function(req,res,next){
    //定义一个str  自动拼接 专门储存从客户端发来的请求体数据
    let str=""
    //监听req的data 事件
    req.on('data',function(chuck){
        str+=chuck
    })
    //监听req的end事件
    req.on('end',function(){
        console.log(str);
        //调用qs.parse()方法,将查询字符串解析为对象
        const body =qs.parse(str)
        //用的为同一个req res 挂载body 使下游路由可以使用
        req.body = body
        next()
    })
})
app.post('/user',function(req,res){
    res.send(req.body)
})
----------------------------------------------------------------
封装自定义中间件为模块:
const qs = require('querystring')
//使用变量接受自定义中间件
const bodyParser = function(req,res,next){
    let str=""
    req.on('data',function(chunck){
        str +=chunck
    })
    req.on('end',function(){
        console.log(str);
        //调用qs.parse()方法,将查询字符串解析为对象
        const body =qs.parse(str)
        //用的为同一个req res 挂载body 使下游路由可以使用
        req.body = body
        next()
    })
}
//将自定义中间件提供给外部
module.exports = bodyParser
-----------------------------------------------
//请求访问自定义中间件模块
const customBodyParser = require('./fengcenter')
//解析表单数据的中间件
app.use(customBodyParser

用req.body接收post客户端的数据;req.query接收get请求;使用post请求时需要解析数据中间件app.use(express.urlencoded({extended:false}))

相关文章
|
3月前
|
开发框架 JSON 中间件
Go语言Web开发框架实践:路由、中间件、参数校验
Gin框架以其极简风格、强大路由管理、灵活中间件机制及参数绑定校验系统著称。本文详解其核心功能:1) 路由管理,支持分组与路径参数;2) 中间件机制,实现全局与局部控制;3) 参数绑定,涵盖多种来源;4) 结构体绑定与字段校验,确保数据合法性;5) 自定义校验器扩展功能;6) 统一错误处理提升用户体验。Gin以清晰模块化、流程可控及自动化校验等优势,成为开发者的优选工具。
|
11月前
|
JavaScript 前端开发 中间件
探索后端技术:Node.js与Express框架的完美融合
【10月更文挑战第7天】 在当今数字化时代,Web应用已成为日常生活不可或缺的一部分。本文将深入探讨后端技术的两大重要角色——Node.js和Express框架,分析它们如何通过其独特的特性和优势,为现代Web开发提供强大支持。我们将从Node.js的非阻塞I/O和事件驱动机制,到Express框架的简洁路由和中间件特性,全面解析它们的工作原理及应用场景。此外,本文还将分享一些实际开发中的小技巧,帮助你更有效地利用这些技术构建高效、可扩展的Web应用。无论你是刚入门的新手,还是经验丰富的开发者,相信这篇文章都能为你带来新的启发和思考。
|
前端开发 API 开发者
Next.js 实战 (五):添加路由 Transition 过渡效果和 Loading 动画
这篇文章介绍了Framer Motion,一个为React设计的动画库,提供了声明式API处理动画和页面转换,适合创建响应式用户界面。文章包括首屏加载动画、路由加载Loading、路由进场和退场动画等主题,并提供了使用Framer Motion和next.js实现这些动画的示例代码。最后,文章总结了这些效果,并邀请读者探讨更好的实现方案。
281 0
Next.js 实战 (五):添加路由 Transition 过渡效果和 Loading 动画
|
10月前
|
Web App开发 JSON JavaScript
Node.js 中的中间件机制与 Express 应用
Node.js 中的中间件机制与 Express 应用
|
10月前
|
缓存 负载均衡 JavaScript
构建高效后端服务:Node.js与Express框架实践
在数字化时代的浪潮中,后端服务的重要性不言而喻。本文将通过深入浅出的方式介绍如何利用Node.js及其强大的Express框架来搭建一个高效的后端服务。我们将从零开始,逐步深入,不仅涉及基础的代码编写,更会探讨如何优化性能和处理高并发场景。无论你是后端新手还是希望提高现有技能的开发者,这篇文章都将为你提供宝贵的知识和启示。
|
10月前
|
缓存 前端开发 JavaScript
JavaScript前端路由的实现原理及其在单页应用中的重要性,涵盖前端路由概念、基本原理、常见实现方式
本文深入解析了JavaScript前端路由的实现原理及其在单页应用中的重要性,涵盖前端路由概念、基本原理、常见实现方式(Hash路由和History路由)、优点及挑战,并通过实际案例分析,帮助开发者更好地理解和应用这一关键技术,提升用户体验。
402 1
|
10月前
|
JavaScript 安全 中间件
深入浅出Node.js中间件机制
【10月更文挑战第36天】在探索Node.js的奥秘之旅中,中间件的概念如同魔法一般,它让复杂的请求处理变得优雅而高效。本文将带你领略这一机制的魅力,从概念到实践,一步步揭示如何利用中间件简化和增强你的应用。
|
10月前
|
消息中间件 JavaScript 中间件
深入浅出Node.js中间件机制
【10月更文挑战第24天】在Node.js的世界里,中间件如同厨房中的调料,为后端服务增添风味。本文将带你走进Node.js的中间件机制,从基础概念到实际应用,一探究竟。通过生动的比喻和直观的代码示例,我们将一起解锁中间件的奥秘,让你轻松成为后端料理高手。
130 1
|
11月前
|
Web App开发 JavaScript 中间件
构建高效后端服务:Node.js与Express框架的完美结合
【10月更文挑战第21天】本文将引导你走进Node.js和Express框架的世界,探索它们如何共同打造一个高效、可扩展的后端服务。通过深入浅出的解释和实际代码示例,我们将一起理解这一组合的魅力所在,并学习如何利用它们来构建现代Web应用。
323 1
|
11月前
|
JSON JavaScript 前端开发
Node.js Express 框架
10月更文挑战第7天
93 2