- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我开发了一个 NodeJs+express 应用程序,在 IBM Cloud 中部署为 Cloud Foundry 应用程序。我想执行相互身份验证(客户端和服务器证书)以控制传入流量和对我的应用程序的请求。我的证书由 Secure Gateway 生成,如 here 所述将我的应用程序配置为云目标(从本地客户端访问)。
安全网关已生成以下 pem 文件:服务器的主要证书、中间证书和根证书以及目标证书和 key 。在文档中有一个非常清楚的 Nodejs example使用 tls.createServer。
在我的场景中存在一些差异:首先,我处于相反的场景(本地客户端通过创建隧道的安全网关连接到云应用程序)。其次,这是这篇文章的主要原因,我的应用程序部署为 CF 应用程序。
阅读关于 HTTP routing 的 CF 文档我发现 IBM 云仅使用端口 80 和 443,然后通过 HTTP 将请求转发到应用程序正在监听的端口(例如,如果我的 NodeJs 在端口 6001 上运行并且我在端口 443 上调用云端点,GoRouter将通过 HTTP 将请求转发到正确的端口,添加 X-Forwarded-Proto
header 以向应用程序传递用于请求的原始协议(protocol)的信息。
考虑到这一点(假设这是正确的),在我的 NodeJs 代码中我不能使用像 https.createServer(opts, app)
这样的东西,因为所有到达 App Container 的请求都将是通过 HTTP。
阅读 CF 文档 here我知道可以告诉 CF 将证书转发到我的应用程序,但有些事情我无法真正理解。
首先,在 Load Balancer 或 GoRouter 终止 TLS 有什么区别?这个选择背后的原因是什么?
我的第二个问题是,当证书作为 HTTP header 转发到我的应用程序后,处理证书的正确方法是什么?这是因为我的 NodeJs 服务器将是一个 http 服务器,以标准方式 http.createServer(app)
使用 express 创建。
感谢所有帮助我解决这个问题的人。显然,如果您有任何示例或建议,那将非常有帮助。
最佳答案
Reading CF documentation about HTTP routing I figured out that IBM cloud only uses ports 80 and 443 and then forwards the requests via HTTP to the ports the app is listening to (for example if my NodeJs is running on port 6001 and I call the cloud endpoint on port 443, the GoRouter will forward the request via HTTP to the correct port, adding the X-Forwarded-Proto header to pass the application the information of the original protocol used for the request.
Having this in mind (assuming this is correct), in my NodeJs code I cannot use something like https.createServer(opts, app) giving that all the requests coming to the App Container will be via HTTP.
没错。
First of all what is the difference between terminating TLS at Load Balancer or at GoRouter? What are the reasons behind this choice?
这仅适用于您运行自己的 Cloud Foundry 平台的情况。如果您将应用程序部署到由其他人运营的 Cloud Foundry 平台,他们将做出此决定,这不会影响您作为用户。
作为运营商,这是您需要做出的选择。根据您的选择,需要进行一些权衡。
您可以在 LB 处终止。这通常是最快的,因为 LB 在处理 TLS/SSL 时非常有效。然后 LB 可以将未加密的流量转发到 Gorouter,这减少了 Gorouter 的工作,但代价是不对两者之间的流量进行加密(可能不太好,具体取决于安全要求)。在这种情况下,LB 有责任添加 x-forwarded-*
header 。
浏览器 -> HTTPS -> LB -> HTTP -> Gorouters -> HTTP -> 你的应用
您可以使用第 4 层 LB 并在您的 Gorouter 之间平衡连接。这使 Gorouter 能够终止 TLS/SSL。他们在这方面非常有效,但不如大多数 LB。这也会让你在 Gorouter 的请求路径中加密。在这种情况下,Gorouter 负责添加 x-forwarded-*
header 。
浏览器 -> HTTPS -> LB -> HTTPS -> Gorouters -> HTTP -> 你的应用
您可以在 LB 处终止,但在 LB 和 Gorouter 之间打开一个新的 TLS/SSL session 。这是效率最低的选项,因为它需要终止两个 TLS/SSL session ,但它在 Gorouter 的请求路径中提供了加密。它也往往是与非第 4 层 LB 一起工作时最灵活的,它可以让您的 LB 检查 HTTP 流量,因为您要在 LB 处终止 session 。在这种情况下,LB 有责任添加 x-forwarded-*
header 。
浏览器 -> HTTPS( session A)-> LB -> HTTPS( session B)-> Gorouters -> HTTP -> 你的应用
同样,如果您没有运行 Cloud Foundry 平台,那么您可以忽略它。
My second question is which is the correct way of handling the certificates once they are forwarded to my application as HTTP headers? This is due to the fact the my NodeJs server will be an http server, created with express in the standard way http.createServer(app).
您不需要对创建服务器的方式做任何花哨的事情。您需要做的就是查看 x-forwarded-*
header 并使用它们做出决定。
请求是通过 HTTPS 传入的吗?查看 x-forwarded-proto
,它应该设置为 https
对于 HTTPS 请求或查看 x-forwarded-port
,对于 HTTPS 请求应设置为 443
。
是否随请求提供了客户端证书?查看 X-Forwarded-Client-Cert
。如果它包含证书,则客户端提供了证书。
客户端的证书是否有效?如果您的应用收到请求,则客户端的证书有效。您知道这一点,因为平台会为您处理该部分。由于平台(LB 或 Gorouter)正在终止 TLS/SSL 连接,因此它有责任验证证书。如果您的应用收到请求并且设置了 x-forwarded-client-cert
,则该证书有效。
我如何根据客户端证书做出授权决定?这有点棘手,但通常您会从 x-forwarded-client- 中提取证书cert
,读取/解析它并根据证书内容做出决定(我们知道这是有效的平台)。您很可能会查看主题名称并将其视为用户名。然后查找该用户的角色或权限。但是,您如何处理这取决于您作为开发者。
希望对您有所帮助!
关于node.js - 使用 NodeJS+express 在 Cloud Foundry 应用程序中进行相互身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52328821/
这个问题已经有答案了: Resolve build errors due to circular dependency amongst classes (12 个回答) 已关闭 3 个月前。 如何允许
让 2 个 Swing 部件做同样的工作是很常见的。例如,我们可以在工具栏中使用一个 button 作为“保存”按钮,而 JMenuItem (文件保存...)也可以做同样的事情。 我的问题是: 有没
我使用 fragment 已经有一段时间了,但我经常遇到一个让我烦恼的问题。 fragment 有时会相互吸引。现在,我设法为此隔离了一个用例,它是这样的: Add fragment A(也使用 ad
我正在使用具有相互 SSL 安全性的 WCF 服务,我想检查一下我对何时使用什么证书的理解。 这是正确的吗? 客户端将客户端公共(public)证书交给服务器 服务器将服务器公共(public)证书交
假设您有一个相互 SSL 服务,除了 SSL 之外,它还有应用程序身份验证。因此,客户端提供证书(以及服务器),但客户端请求(例如 REST 请求)还包含后端应用程序服务器用于验证的用户名/密码。 就
有人让 Android uiautomator 可以同时在多个设备上运行,但做不同的事情吗? 我的意思是,我希望我的测试同时启动设备和应用程序,然后设备 A 执行设备 B 必须使用react的操作。这
我目前正在尝试在客户端和服务器之间实现双向 TLS 身份验证。我遇到了一个 SSL 错误,它的描述性不强。 StackOverflow 也没有太多与之相关的问题,因为大多数时候它是互联网上的单向 TL
这里是新手。我正在做我的第一个元素,我想为不同的人(普通人、 worker 、农民等)提供 slider ,但我不知道如何放置多个 slider 以及如何让它们全部工作。我从 W3schools 获取
我创建了一张翻转卡片,但卡片内的所有 div 似乎都浮在彼此之上。我希望 div 彼此相邻。 我看了很多问题,但似乎找不到答案。我尝试了多种显示:内联;职位:相对;向左飘浮;清除:两者;但我似乎无法让
我正在使用此控件来安排时间。我有一个单选按钮列表,然后是多个内容 Pane 。根据内容,我想在正确的控件中淡入淡出。但出于某种原因,在 div 上放置一个 float 并设置 z-index 并不能使
有什么方法可以解密双向 SSL(客户端和服务器,两种方式)? 我找到了这个链接:https://www.wireshark.org/lists/wireshark-users/201001/msg00
我正在开发一个 Web 应用程序,安全性是我们在此应用程序中的主要关注点之一。我正在查看不同的 API 安全方法(在 OWASP 中提到),无法理解相互 SSL 身份验证和基于 token 的身份验证
我正在尝试使用分配给 kube-dns 服务的集群 IP 从 dnstools pod ping kube-dns 服务。 ping 请求超时。在同一个 dnstools pod 中,我尝试使用暴露的
过去几天我一直在研究这个问题,但我一无所获。 场景是: 现场的 iOS 应用程序将调用我的 REST 服务 (.NET)。我的 REST 服务将使用相互 SSL 握手调用 Apache Web 服务。
我正在尝试向 java swing 应用程序添加 3 个 JSlider,以便三个 slider 的总值(value)总和为 100。每个 slider 都是一个概率, slider A 是将值添加到
我们正在使用 java 客户端(openJDK 1.8.0) 调用需要相互身份验证的 api。为此,我们使用 Java 标准 JKS 文件作为 keystore 和信任库(包含信任证书和身份证书/私钥
有人告诉我使用双向身份验证连接到客户的服务器。服务器身份验证工作顺利,但我们在获取客户端身份验证方面遇到了巨大的麻烦。让我试着解释一下我们的麻烦。 前段时间我公司在 GeoTrust 购买了一个证书,
正在试用 PAW 并且非常喜欢它。我唯一无法正常工作的是使用 HTTPS 相互身份验证。我需要与之交互的一些 API 需要相互验证的 https。 如何告诉 PAW 使用证书进行身份验证?该证书已经在
我们有一个在 Jboss EAP 5.1 中部署并使用 Spring 2.5 已经运行了一年多的 CXF webservice 我们现有的客户证书管理策略如下: 对于非 PROD,证书名为“NAME-
我正在创建一个将调用 API 的 Windows 服务。对于这个过程,我正在尝试建立相互(双向)SSL 身份验证。因为我是新手。我尝试实现一个简单的客户端和服务器项目,它们将相互进行身份验证。 我已经
我是一名优秀的程序员,十分优秀!