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

武汉网站建设的公司品牌网络推广方案

武汉网站建设的公司,品牌网络推广方案,自己做网站怎么优化,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/174944.html

相关文章:

  • 适合大网站做安全性测试的工具做营销策划的公司
  • top模板wordpress西安seo站内优化
  • 网站建网站建设网站论坛推广的特点
  • 个人网站开发开题报告莱阳seo排名
  • 广东网站设计招工.seo关键词选择及优化
  • 以后做网站发展前途抖音竞价推广怎么做
  • html5 wap网站模板电商广告
  • 上蔡县住房和城乡建设局网站seo培训讲师招聘
  • seo+网站排名谷歌查询关键词的工具叫什么
  • 广州易网网站建设中山谷歌推广
  • 做dj网站需要站长工具 seo查询
  • 企业管理咨询有限公司的经营范围如何做好网站推广优化
  • 网站开发建设类合同网页设计制作网站模板图片
  • 高创园网站建设方案华为seo诊断及优化分析
  • 聋哑工作设计做网站品牌策划运营公司
  • 做网站反复修改百度快速优化排名软件
  • 公司转让流程南京seo招聘
  • 数学建模代做网站网站网络推广公司
  • 网站建设复制别人文章违法吗影视网站怎么优化关键词排名
  • ui设计工资宁波seo推广定制
  • 外贸网站建设与推广杭州seo营销
  • 空中客车网站建设需求网络建站平台
  • 网站开发公司杭州网站建设站长统计app网站
  • 网站建设 设计 优化 维护网站seo外链平台
  • 龙岗网站设计代理商seo案例分析
  • 旅游兼职网站建设北京seo服务商找行者seo
  • 盐城微信公众平台网站制作佛山网站快速排名提升
  • 如何查找织梦网站后台网站交易
  • 企业官方网站制作推广软件软文模板app
  • 功能型网站多少钱靠谱的广告联盟