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}))

相关文章
|
15天前
|
开发框架 JSON 中间件
Go语言Web开发框架实践:路由、中间件、参数校验
Gin框架以其极简风格、强大路由管理、灵活中间件机制及参数绑定校验系统著称。本文详解其核心功能:1) 路由管理,支持分组与路径参数;2) 中间件机制,实现全局与局部控制;3) 参数绑定,涵盖多种来源;4) 结构体绑定与字段校验,确保数据合法性;5) 自定义校验器扩展功能;6) 统一错误处理提升用户体验。Gin以清晰模块化、流程可控及自动化校验等优势,成为开发者的优选工具。
|
3月前
|
JavaScript 前端开发 API
|
3月前
|
前端开发 JavaScript NoSQL
使用 Node.js、Express 和 React 构建强大的 API
本文详细介绍如何使用 Node.js、Express 和 React 构建强大且动态的 API。从开发环境搭建到集成 React 前端,再到利用 APIPost 高效测试 API,适合各水平开发者。内容涵盖 Node.js 运行时、Express 框架与 React 库的基础知识及协同工作方式,还涉及数据库连接和前后端数据交互。通过实际代码示例,助你快速上手并优化应用性能。
|
7月前
|
数据采集 人工智能 自然语言处理
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
1881 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
8月前
|
缓存 监控 JavaScript
Vue.js 框架下的性能优化策略与实践
Vue.js 框架下的性能优化策略与实践
|
8月前
|
Web App开发 JSON JavaScript
Node.js 中的中间件机制与 Express 应用
Node.js 中的中间件机制与 Express 应用
|
8月前
|
缓存 负载均衡 JavaScript
构建高效后端服务:Node.js与Express框架实践
在数字化时代的浪潮中,后端服务的重要性不言而喻。本文将通过深入浅出的方式介绍如何利用Node.js及其强大的Express框架来搭建一个高效的后端服务。我们将从零开始,逐步深入,不仅涉及基础的代码编写,更会探讨如何优化性能和处理高并发场景。无论你是后端新手还是希望提高现有技能的开发者,这篇文章都将为你提供宝贵的知识和启示。
|
8月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
150 2
|
JavaScript
Node.js学习笔记----路由
Node.js学习笔记----路由
|
JavaScript
Node.js学习笔记(十一、路由)
Node.js学习笔记(十一、路由)
174 0
Node.js学习笔记(十一、路由)

热门文章

最新文章