首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Express.js - Helmet.js和其他中间件,以及安装的应用程序?

Express.js - Helmet.js和其他中间件,以及安装的应用程序?
EN

Stack Overflow用户
提问于 2016-03-11 03:49:36
回答 1查看 1.1K关注 0票数 1

在最近的一个学习项目中,我使用三个Express.js应用程序将项目分成更易于管理的部分。

一个应用程序是“主”应用程序,它是监听连接的应用程序。另外两个安装在主应用程序的特定路径上。

在主应用程序上调用app.disable('x-powered-by');以禁用X驱动的标头是否就足够了,还是需要在每个安装的应用程序中都这样做?

类似地,我正在研究如何使用Helmet.js来尝试为整个项目添加一些额外的安全性。在主应用程序中包含来自Helmet.js的任何中间件,还是需要在挂载的应用程序中定义这些中间件?

我不觉得我理解一些设置和中间件如何影响挂载的Express.js应用程序,并希望得到更多经验的任何人的进一步解释。

编辑:在使用app.disable('x-powered-by')并检查服务器的响应之后,如果我没有在主应用程序实例和任何已挂载的应用程序实例中禁用它,X驱动的标头就会出现。因此,我假设Helmet.js中间件的操作方式是相同的,但我不能百分之百肯定。有人能确认这是否是预期的行为吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-04-29 18:22:41

你说的一切都是对的。

听起来你在做这样的事:

代码语言:javascript
复制
var express = require('express')

var mainApp = express()
var miniAppA = express()
var miniAppB = express()

mainApp.use('/a', miniAppA)
mainApp.use('/b', miniAppB)

mainApp.listen(3000)

这是一个做事情的好方法,但标题将被覆盖在子应用程序中,正如您所看到的。

您可以使用Express 4的路由器功能来缓解这种情况。不用用express()制作新的迷你应用程序,你可以使用express.Router()。这些是功能较少的Express应用程序(例如,它们不以相同的方式设置头)。

像这样的事情也许能解决你的问题:

代码语言:javascript
复制
var express = require('express')

var mainApp = express()
var miniAppA = express.Router()
var miniAppB = express.Router()

mainApp.use('/a', miniAppA)
mainApp.use('/b', miniAppB)

mainApp.listen(3000)
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35931849

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档