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

门窗设计软件免费版seo牛人

门窗设计软件免费版,seo牛人,seo网站关键词,wordpress下载页面模板怎么用目录 1. 目录结构 2. 代码实现 2.1 安装Express 2.2 app.js - 主文件 2.3 authMiddleware.js - 局部生效的中间件 3. 程序运行结果 4. 总结 在Node.js的Express框架中,局部生效的中间件是指仅在特定路由或路由组中生效的中间件。它可以用于权限验证、数据过滤…

目录

1. 目录结构

2. 代码实现

2.1 安装Express

2.2 app.js - 主文件

2.3 authMiddleware.js - 局部生效的中间件

3. 程序运行结果

4. 总结


在Node.js的Express框架中,局部生效的中间件是指仅在特定路由或路由组中生效的中间件。它可以用于权限验证、数据过滤、日志记录等特定功能,而不会影响整个应用的所有请求。下面我们通过代码示例详细介绍如何实现局部生效的中间件。


1. 目录结构

/your-project├── app.js                # 主文件,启动应用├── middleware│   └── authMiddleware.js  # 局部生效的中间件(模拟身份验证)└── package.json          # 项目依赖管理文件

2. 代码实现

2.1 安装Express

如果你还没有安装Express,请先执行以下命令:

npm init -y
npm install express

2.2 app.js - 主文件

app.js是应用的主入口,我们将在这里引入局部中间件,并应用到指定的路由。

// app.js
const express = require('express');
const app = express();// 引入局部中间件
const authMiddleware = require('./middleware/authMiddleware');// 定义公共路由(不需要中间件)
app.get('/', (req, res) => {res.send('<h1>Welcome to the Home Page</h1>');
});// 使用局部中间件的路由
app.get('/dashboard', authMiddleware, (req, res) => {res.send('<h1>Welcome to the Dashboard</h1>');
});app.get('/profile', authMiddleware, (req, res) => {res.send('<h1>Welcome to Your Profile</h1>');
});// 监听端口
const PORT = 3000;
app.listen(PORT, () => {console.log(`Server is running on http://localhost:${PORT}`);
});

说明:

  • authMiddleware 仅用于/dashboard/profile路由,而/路由不受影响。

  • 只有访问受保护的路由时,中间件才会执行身份验证。


2.3 authMiddleware.js - 局部生效的中间件

authMiddleware.js是一个模拟身份验证的中间件,它检查请求中是否带有?auth=true参数,来决定是否允许访问。

// middleware/authMiddleware.js
const authMiddleware = (req, res, next) => {if (req.query.auth === 'true') {console.log('Authentication successful');next(); // 继续执行路由处理} else {res.status(403).send('<h1>Access Denied: Authentication Required</h1>');}
};module.exports = authMiddleware;

说明:

  • 这个中间件检查查询参数auth是否为true,如果是,则允许访问,否则返回403错误,并提示“访问被拒绝”。


3. 程序运行结果

启动应用:

node app.js

然后访问以下地址:

  • 访问 http://localhost:3000/(无需认证)

    • 终端无额外输出

    • 页面显示:

      <h1>Welcome to the Home Page</h1>
      
  • 访问 http://localhost:3000/dashboard

    • 终端无输出,页面显示:

      <h1>Access Denied: Authentication Required</h1>
      
  • 访问 http://localhost:3000/dashboard?auth=true

    • 终端输出:

      Authentication successful
      
    • 页面显示:

      <h1>Welcome to the Dashboard</h1>
      

4. 总结

  • 局部中间件 只影响特定的路由,而不会全局生效。

  • 通过在路由定义中传递中间件(如app.get('/dashboard', authMiddleware, handler)),可以控制它的作用范围。

  • 本示例使用了简单的身份验证逻辑(查询参数),在实际应用中可以扩展为基于JWT或Session的认证机制。

希望本教程能帮助你理解Node.js的局部生效中间件!

 

http://www.dtcms.com/wzjs/407063.html

相关文章:

  • 商丘做网站的费用seo超级外链工具
  • 上海企业排行榜网站优化排名首页
  • 上海疫情饿死了多少人网站seo 工具
  • wordpress网站定制太原做网络推广的公司
  • 网站开发字体过大百度推广助手app
  • 崇明做网站公司网站建设报价方案
  • 做营销的有那么网站小程序
  • 手机网站和微信网站有哪些百度商家平台
  • 查派网站建设网站推广怎么做有效果
  • 学做网站的软件济南百度推广代理商
  • 网站开发任务书今天的新闻主要内容
  • 做网站万网百度推广登录平台
  • 成都动态网站制作营销型网站制作成都
  • 网站建设技术服务的方式是什么意思百度推广怎么做的
  • ui工程师工资一般多少安徽百度seo教程
  • 做视觉影像网站用什么软件系统成都排名seo公司
  • 玉儿做春梦网站百度商家版下载
  • 软件开发公司照片上海最大的seo公司
  • 环企优站网站建设精准营销策略都有哪些
  • 全国工商网湖南长沙seo
  • 做网站是什么专业西安seo王尘宇
  • 济南工程网站建设怎么让某个关键词排名上去
  • 阿里巴巴1688怎么做网站宁波谷歌seo
  • 网站维护都要做什么百度链接提交收录入口
  • 动态公司网站设计晨阳seo服务
  • 做网站 接单营销活动方案
  • 空间域名续费 网站维护发票如何开免费网站推广网站在线
  • 网站建设设计服务疫情最新数据消息地图
  • 网站添加合适图片google浏览器网页版
  • 上海做saas平台网站的公司河北网络科技有限公司