当前位置: 首页 > news >正文

想做网站多少钱创同盟做网站

想做网站多少钱,创同盟做网站,英文网站建设szjijie,佛山专业画册设计公司Express 中间件系统 的详细讲解,包括全局中间件、路由中间件、静态资源中间件、请求体解析中间件,以及使用注意事项👇 🌐 一、什么是中间件(Middleware)? 中间件是 函数,在请求到达…

Express 中间件系统 的详细讲解,包括全局中间件、路由中间件、静态资源中间件、请求体解析中间件,以及使用注意事项👇


🌐 一、什么是中间件(Middleware)?

中间件是 函数,在请求到达路由处理器之前被调用,用于拦截、修改请求或响应,或者终止请求处理流程。

中间件函数格式:

(req, res, next) => { /* your logic */ }

调用 next() 表示继续传递请求给下一个中间件;否则请求会被“卡住”。


📌 二、全局中间件(应用级)

示例 1:日志中间件(所有请求都会执行)

app.use((req, res, next) => {console.log(`[${new Date().toISOString()}] ${req.method} ${req.url}`);next(); // 继续执行下一个中间件
});

🚏 三、路由中间件(局部)

只对特定路由生效的中间件:

const checkAuth = (req, res, next) => {if (req.query.token === '123') {next();} else {res.status(401).send('Unauthorized');}
};app.get('/secure', checkAuth, (req, res) => {res.send('Access granted!');
});

📁 四、静态资源中间件

内置中间件 express.static() 用于托管静态文件(HTML、CSS、JS、图片等):

app.use(express.static('public')); // 访问 public 文件夹// 假设 public 中有 index.html,可以直接通过 http://localhost:3000/index.html 访问

🧾 五、获取请求体数据的中间件

1. 解析 JSON 格式

app.use(express.json());

2. 解析表单格式(x-www-form-urlencoded)

app.use(express.urlencoded({ extended: true }));

示例 POST 路由:

app.post('/login', (req, res) => {const { username, password } = req.body;res.send(`用户名:${username}, 密码:${password}`);
});

⚠️ 六、使用注意事项

注意事项说明
中间件顺序中间件是按顺序执行的,先定义的先执行
next() 必须调用否则请求会卡住,不继续执行后续中间件或路由
错误处理中间件中间件中捕获错误时要调用 next(err),Express 会自动进入错误处理中间件
静态中间件要放前面否则可能被其他中间件或路由拦截
不要滥用全局中间件建议用局部中间件提高性能与可维护性

🎁 七、完整示例

const express = require('express');
const app = express();
const port = 3000;// 中间件
app.use(express.json());
app.use(express.urlencoded({ extended: true }));
app.use(express.static('public'));// 全局日志中间件
app.use((req, res, next) => {console.log(`[LOG] ${req.method} ${req.url}`);next();
});// 路由中间件示例
const auth = (req, res, next) => {if (req.query.token === '123') next();else res.status(401).send('未授权');
};app.get('/public-info', (req, res) => res.send('Everyone can see this'));app.get('/private-info', auth, (req, res) => res.send('This is protected'));app.post('/form', (req, res) => {res.send(req.body);
});app.listen(port, () => {console.log(`App running at http://localhost:${port}`);
});
http://www.dtcms.com/a/459924.html

相关文章:

  • cadisen卡迪森手表网站高端app开发
  • 网站前后台贵州seo培训
  • 快速搭建网站的工具有哪些电商网站建设存在哪些问题
  • 关于做网站的策划书建设网站什么语言
  • 手机网站设置方法如何做好口碑营销
  • 老鹰主机做的网站vi设计对企业的意义
  • 大连华南网站制作公司cms是什么意思体积
  • 北京做网站的开发公司wordpress主题偷
  • 大连网站排名推广企业管理研究生学校排名
  • 用jsp做网站的技术路线wordpress 博客不显示不出来
  • 旅游电子商务网站有哪些青岛seo霸屏
  • 做商业网站去哪里弄好温州网站建设制作公司
  • 手机qq钓鱼网站怎么做莱芜网站建设流程
  • 个人网站设计与实现结论网站开发地图导航页面
  • 高端网站设计新感觉建站江苏荣邦建设有限公司网站
  • 湖南省建设厅安许审核公布网站网站建设目的定位
  • 海口免费网站建设广州有哪些软件开发公司
  • 莆田个人外贸网站建设垂直网站建设步骤
  • 朋友 合同 网站制作成都网站建设优化前十
  • win 2003 网站 管理员云浮各类免费建站
  • 有关网站建设的外文文献dw个人网页模板
  • 网站漏洞解决wordpress 商城 app
  • 网站建设面试专门做瑜伽的网站
  • 关于网站建设的新闻php免费开源cms系统
  • 上海网站搜索引擎优化wordpress 导航栏 搜索
  • 外贸自己做网站好不好用手机建网站
  • 网站维护运营怎么做沈阳德泰诺网站建设
  • 西安免费公司网站设计郴州网站建设推广公司
  • 网站开发工作流程邯郸哪儿做网站好
  • 建网站 需要签署协议阿里云里做网站能上百度首页么