Express框架中的res

news/2024/9/23 4:26:24/

中间件由两部分组成,中间件方法和请求处理函数;

中间件方法由express提供,负责拦截请求,请求处理函数由开发人员提供,负责处理请求;

app.get(‘请求路径’,‘处理函数’); //接收并处理get请求

app.post(‘请求路径’,‘处理函数’); //接收并处理post请求

可以对同一个请求设置多个中间件,对同一个请求进行多次处理;

默认情况下,请求从上到下一次匹配中间件,一单匹配成功,终止匹配;

可以调用next方法将请求的控制权交给下一个中间件,直到遇到结束请求的中间件;

app.get(‘/request’,(req,res,next)=>{

req.name = ‘张三’;

next();

});

app.get(‘/request’,(req,res)=>{

res.send(req.name);

})

2.1 app.use中间件用法

使用app.use()方法定义中间件;

app.use匹配所有的请求方式,可以直接传入请求处理函数,代表接收所有请求;

app.use((req,res,next)=>{

console.log(‘请求走了app.use中间件’);

next();

})

//中间件函数有三个参数,分别为请求对象req,响应对象res,释放控制权方法next;

//中间件函数中的代码执行完成后需要调用next()方法,才开始执行下一个中间件,否则请求将挂起;

app.use第一个参数也可以传入请求地址,代表不论是什么请求方式,只要是这个请求地址就接收这个请求;

app.use(‘/admin’,(req,res,next)=>{

console.log(‘请求走了app.use/admin中间件’);

next();

})

2.2中间件的应用

// 引入express框架

const express = require(‘express’);

//创建网站服务器

const app = express();

// //匹配所有的请求路径,网站公告

// app.use((req,res,next)=>{

// res.send(‘当前网站正在维护…’);

// })

app.use(‘/admin’,(req,res,next)=>{

// 用户没有登录

let isLogin = true;

//如果用户登录

if(isLogin){

//让请求继续向下执行

next();

}else {

//如果用户没有登录,直接对客户端作出响应

res.send(‘您还没有登录,不能访问这个页面’);

}

})

app.get(‘/admin’,(req,res)=>{

res.send(‘您已经登录,可以访问当前页面’);

})

//访问除了上边写过的页面外,其他所有页面都不存在

app.use((req,res,next)=>{

//为客户端响应404状态码,以及提示信息

res.status(404).send(‘当前访问的页面不存在’);

})

//监听端口

app.listen(3000);

console.log(‘网站服务器启动成功’);

2.3错误处理中间件

在程序执行过程中,不可避免的会出现无法预料的错误,比如读取文件失败,数据库连接失败,

错误处理中间件是一个集中处理错误的地方;

//引入express框架

const express = require(‘express’);

const fs = require(‘fs’);

//创建网站服务器

const app = express();

app.get(‘/index’, (req, res, next) => {

// throw new Error(‘程序发生了未知错误’)

fs.readFile(‘./01.js’, ‘utf8’, (err, result) => {

//读取文件失败

if (err != null) {

//把错误传递给下边捕获错误信息

next(err);

}else {

//读取文件成功响应文件内容

res.send(result)

}

})

// res.send(‘程序正常执行’);

})

//错误处理中间

//里边传递一个请求的处理函数,第一个参数err错误对象,第二个req请求对象

//第三个是响应对象,第四个是next

app.use((err, req, res, next) => {

//服务器发生错误状态码是500,err.massage保存错误信息

res.status(500).send(err.message);

})

//监听端口

app.listen(3000);

console.log(‘网站服务器启动成功’);

2.4捕获错误

在node.js中,异步api的错误信息都是通过回调函数获取的,支持Promise对象的异步API发生错误可以通过catch方法捕获;

try…catch可以捕获异步函数以及同步代码在执行过程中发生信息,但是不能其他类型API发生的错误;

app.get(“/”, async (req, res, next) => {

try {

await User.find({name: ‘张三’})

}catch(ex) {

next(ex);

}

});

//错误处理中间

app.use((err,req,res,next)=>{

res.status(500).send(err.message);

})

3.模块化路由

//调用express下面的Router方法,返回值是一个路由对象,

//然后可以在home路由对象下边挂载二级路由

const home = express.Router();

// 将路由和请求路径进行匹配

app.use(‘/home’, home);

// 在home路由下继续创建路由

home.get(‘/index’, () => {

// /home/index

res.send(‘欢迎来到博客展示页面’);

});

// home.js 博客展示页面的路由

const home = express.Router();

home.get(‘/index’, () => {

res.send(‘欢迎来到博客展示页面’);

});

module.exports = home;

// admin.js 博客管理路由

const admin = express.Router();

admin.get(‘/index’, () => {

res.send(‘欢迎来到博客管理页面’);

});

module.exports = admin;

// app.js 创建服务器页面引入博客展示页面的路由和 博客管理路由

const home = require(‘./route/home.js’);

const admin = require(‘./route/admin.js’);

app.use(‘/home’, home);

app.use(‘/admin’, admin);

4.GET参数获取

Express框架中使用req.query即可获取GET参数,框架内部将GET参数转换为对象并返回;

// 接收地址栏中问号后面的参数

专业技能

一般来说,面试官会根据你的简历内容去提问,但是技术基础还有需要自己去准备分类,形成自己的知识体系的。简单列一下我自己遇到的一些题

  • HTML+CSS

  • JavaScript

  • 前端框架

  • 前端性能优化

  • 前端监控

  • 模块化+项目构建

  • 代码管理

  • 信息安全

  • 网络协议

  • 浏览器

  • 算法与数据结构

  • 团队管理

最近得空把之前遇到的面试题做了一个整理,包括我本人自己去面试遇到的,还有其他人员去面试遇到的,还有网上刷到的,我都统一的整理了一下,希望对大家有用。

其中包含HTML、CSS、JavaScript、服务端与网络、Vue、浏览器等等

由于文章篇幅有限,仅展示部分内容


http://www.ppmy.cn/news/1523862.html

相关文章

【云备份】可视化客户端----QT开发➕QT数据库编程

文章目录 一、 需求分析二、 概念结构设计三、逻辑结构设计1. 用户表 (users)2. 客户端本地文件信息表 (upload_files)3. 备份记录表 (backup_records)4. 服务端备份文件信息表 (backup_files) 四、 开发工具五、具体实现(一) 客户端程序运行演示 一、 需…

后端Web之SpringBoot原理

目录 1.配置优先级 2.Bean 3.SpringBoot原理 1.配置优先级 SpringBoot中支持三种格式的配置文件: .application.properties、application.yml和application. yaml。它们的配置优先级分别降低。虽然springboot支持多种格式配置文件,但是在项目开发时,推荐统一使用…

系统性能分析工具sysstat之sar命令以及nginx中打开gzip使用配置gzip_http_version值为1.0和1.1时遇到的结果乱码问题

一、系统性能分析工具:sysstat之sar命令 服务器维护常用的管理命令有很多:top、ps,、pstree、vmstat、iostat、iotop等,但好像都不全面,这里有一个比较系统全面的性能分析工具sar(System Activity Reporter系统活动情况…

Redis 缓存淘汰算法策略详解

引言 Redis 作为一款高性能的内存数据库,在处理大量数据时,由于内存有限,需要在数据达到设定的内存上限后,使用缓存淘汰策略来决定哪些数据应该被移除,以腾出空间存储新的数据。这一过程被称为缓存淘汰,通…

【网络安全】-文件上传漏洞实战-upload-labs(0~16)

准备&#xff1a; 一句话木马&#xff1a;<? php eval($_REQUEST[cmd]); ?)> 格式&#xff1a;写入txt文本重命名后缀问.php /.php 格式&#xff0c;看具体要求上传。 Pass-01: 显示页面源代码&#xff0c;发现是js对不合法文件进行检查,上传修改为.jpg的php文件直接…

ArrayList、LinkedList和Vector的区别

ArrayList 容量默认是10&#xff0c;它和 Vector 的底层实现都是基于动态数组&#xff0c;ArrayList 的内部元素可以通过 get 和 set 方法进行访问&#xff1b;LinkedList的底层实现是基于双向链表&#xff0c;当数据量很大或者操作很频繁的情况下&#xff0c;插入和删除元素时…

版权与开源协议:一场创新与自由的边界之争

在数字时代的浪潮中&#xff0c;版权与开源协议作为知识产权领域的两大支柱&#xff0c;既相互依存又暗自较劲&#xff0c;共同绘制着科技创新的宏伟蓝图。本文将带您深入这场创新与自由的边界之争&#xff0c;探讨版权与开源协议之间的微妙关系&#xff0c;以及它们如何共同推…

frame buffer的使用

1. Frame Buffer 的基本概念 Frame buffer 是显卡存储的视频数据&#xff0c;在 Linux 系统中通常被抽象为 /dev/fbX 文件&#xff08;X 表示不同的设备编号&#xff09;。应用程序可以通过这个设备文件直接与显卡进行交互&#xff0c;读写像素数据以显示内容。 2. 使用 Fram…