首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何从servlet验证连接是使用双向SSL建立的?

如何从servlet验证连接是使用双向SSL建立的?
EN

Stack Overflow用户
提问于 2012-10-29 20:26:21
回答 3查看 2.6K关注 0票数 0

我已经编写了一个servlet过滤器来为web应用程序增加安全性。在某些情况下,我想验证与应用程序服务器的连接是否使用双向SSL (TLS1.0)。通常,这是通过HttpServletRequest.getAttribute("javax.servlet.request.X509Certificate")完成的;但是,在我的情况下,应用程序服务器前面有一个反向代理,该代理通过WL-Proxy-Client-Cert标头将客户端证书传递给应用程序服务器。因此,当我检索前面提到的属性时,我得到了最初出现在报头中的客户端证书。我要做的不仅是验证客户端证书,还要确保反向代理和应用程序服务器之间的连接使用双向SSL进行保护。有没有一种方法可以让我在servlet中进行验证?我使用的是SSL10.3.4,JavaEE5。不能将SSL端口配置为需要双向WebLogic,因为同一台服务器上的其他一些服务只需要单向WebLogic。

EN

回答 3

Stack Overflow用户

发布于 2012-10-29 21:45:04

无论客户端是web浏览器还是反向代理,检查客户端证书的过程都是相同的。只需获取"javax.servlet.request.X509Certificate"属性并检查它是否与您的反向代理匹配(基于DN或颁发者)。

只有当应用程序服务器在验证提供给应用程序服务器的证书是代理的证书之后,才想知道向代理服务器提供了什么客户端证书时,WL-Proxy-Client-Cert才会起作用。

票数 0
EN

Stack Overflow用户

发布于 2012-10-31 14:37:34

在使用HttpServletRequest.getAttribute("javax.servlet.request.X509Certificate")的过滤器中,您将在原始请求中获得应用程序服务器所看到的证书:这将是反向代理自己的客户端证书(如果它正在使用的话)。

根据您的需求,如果需要,您可以基于此属性做出与授权相关的决策。您不需要验证是否信任证书本身,因为身份验证应该由应用程序服务器的SSL连接器完成(配置了适当的信任存储区)。

容器中的大多数应用程序可能希望getAttribute("javax.servlet.request.X509Certificate")引用用户的证书,而不是代理的证书。

目前还不清楚以哪种格式获取WL-Proxy-Client-Cert附加头的值,但我将假定使用某种PEM格式。您应该能够转换此内容并将其放入筛选器中的javax.servlet.request.X509Certificate属性中,以免它命中您的筛选器/逻辑的其余部分。这应该是一个表示证书链的java.security.cert.X509Certificate数组(首先是客户端证书,然后是颁发者)。您可以使用CertificateFactory (参见示例)或BouncyCastle的PEMReader进行转换。

您可以在那里验证这些证书,但我想说这样做没有什么意义。当用户和代理之间的连接完成时,这实际上应该在反向代理中完成。如果您不信任代理,它无论如何都可以向您发送它想要的任何证书:您将无法检查用户是否拥有来自工作节点的证书的私钥,只有反向代理可以这样做。

也就是说,您当然可以使用通过这种方式获得的客户端证书做出授权决策(同样,如果您信任反向代理:因此,您必须对以某种方式向您发送信息的反向代理进行身份验证)。

票数 0
EN

Stack Overflow用户

发布于 2012-10-29 21:38:05

除非存在双向SSL身份验证,否则不会有客户端证书。证书的存在就是足够的证明。

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

https://stackoverflow.com/questions/13129097

复制
相关文章
生信技巧 | GNU 并行操作
有些分析需要很长时间,因为它在单个处理器上运行并且有大量数据需要处理。如果数据可以分成块并单独处理,那么问题就被认为是可并行化的。
数据科学工厂
2023/09/20
2630
生信技巧 | GNU 并行操作
如何使用Spark大规模并行构建索引
使用Spark构建索引非常简单,因为spark提供了更高级的抽象rdd分布式弹性数据集,相比以前的使用Hadoop的MapReduce来构建大规模索引,Spark具有更灵活的api操作,性能更高,语法
我是攻城师
2018/05/14
1.5K0
jenkins并行构建
如果需要分别在Chrome、Firefox、IE等浏览器的各个不同版本中对同一个web应用进行UI测试,怎么做呢?
陈不成i
2021/06/01
1.7K0
使用 GNU Screen 的小技巧
对于一般用户而言,命令行终端窗口可能是令人困惑和神秘的。但随着你对 Linux 终端的进一步了解,你很快就会意识到它的高效和强大。不过,也不需要很长时间,你就会想让终端变得更加高效,除了将更多的终端放到你的终端,还有什么高好的方法能够提升你的终端效率呢?
用户1880875
2021/09/06
8220
如何构建用户体验优化体系?
在前几期的直播中,我们为大家介绍了监控和日志相关的一些内容。监控分为三个阶段,基础监控、应用监控、业务监控。前面我们已经分享了基础监控的部分,今天主要为大家带来用户体验优化的一些分享。
嘉为蓝鲸
2023/03/29
1.4K0
如何构建用户体验优化体系?
技术|使用 MinGW 在 Windows 上使用 GNU
在Windows上安装GNU编译器集合(gcc)和其他GNU组件来启用GNUAutotools。
知忆
2021/07/06
1.7K0
如何在庞大代码库上构建并行计算能力?
一、引言 对于商业数据库 [5] [6] [7]、开源数据库[8]、云原生数据库[9] [10] ,或者大数据系统[32],并行计算[33]都是多核处理环境下提高性能的基本技术手段。本文分析如何通过关键抽象来划分层次和管理复杂性,在庞大的 MySQL 代码库上构建并行计算能力,并通过基准测试数据来体现加速效果。 二、摘要 腾讯云托管数据库 TencentDB for MySQL [1] (本机存储,Binlog 复制集群) 和云原生数据库 TDSQL-C for MySQL [2] (共享存储, Red
腾讯云数据库 TencentDB
2023/03/30
5750
如何在庞大代码库上构建并行计算能力?
GreatSQL重磅特性,InnoDB并行并行查询优化测试
GreatSQL马上正式开源了,这次又新增了两个重磅特性:InnoDB事务锁优化 以及 InnoDB引擎的并行查询优化,这两个特性是由华为鲲鹏计算团队贡献的Patch合并而来。
老叶茶馆
2021/08/26
1.1K0
微服务模式下如何实现多模块并行构建发布
在微服务项目中具有很多个服务模块,为了便于管理需要将项目规范化,使用GitLabGroup管理整个项目,每个project对应一个微服务,每个微服务对应一个Jenkins job。开始发布的时候需要我们在手动选择各个服务然后发布。模块很多的时候就不太方便了。
DevOps云学堂
2020/04/22
1.1K0
微服务模式下如何实现多模块并行构建发布
GNU系统概览
GNU系统是一套向上兼容Unix的完全自由的操作系统。GNU代表“GNU's Not Unix”。它的发音是带有g音的单音节。Richard Stallman在1983年9月做出了GNU工程的初始声明。接着在1985年3月又发表了更长的版本,叫做GNU宣言。它被翻译成多种其他语言。
狼啸风云
2019/11/28
1.2K0
使用 CI/CD 优化前端构建的五种策略
如今使用 CI/CD 工具是网页应用程序开发的一个必要条件。作为关键开发路径的一部分,加快构建系统的速度对于提高开发人员的生产效率是至关重要的。
coder_koala
2021/09/22
1.1K0
使用 CI/CD 优化前端构建的五种策略
使用 CI/CD 优化前端构建的五种策略
如今使用 CI/CD 工具是网页应用程序开发的一个必要条件。作为关键开发路径的一部分,加快构建系统的速度对于提高开发人员的生产效率是至关重要的。
用户4456933
2021/07/12
1K0
使用 CI/CD 优化前端构建的五种策略
使用GNU Screen管理持久终端会话
GNU Screen是一种与终端会话配合使用的工具,允许用户在断开连接后恢复会话。Screen可防止会话“超时”或断开SSH连接或本地终端仿真器。单个Screen会话具有托管多个会话或“窗口”的能力。Screen可用于各种任务,例如在终端环境中维护持久性IRC会话和多任务。
苏子晨
2018/08/17
2.1K0
子目录下的html如何访问servlet?
4)子目录下的html如何访问servlet?web.xml和servlet都一样。只有html有变化。
马克java社区
2021/07/07
9110
使用python遍历子目录中的文件
这话真不是随便说的。在做的一个项目中,需要遍历子目录,并将文件保存到列表中,通过Python,几行代码就能实现。
fanzhh
2019/08/20
5.3K0
大分区表的手工并行优化
这段时间饱受大分区表的性能之苦,碰到最大的一个分区表有1个t左右,操作起来每个细节都需要格外小心,我这次和大家分享的案例应用的分区表不是很大,有80G左右。但是这个分区主要分区比较多,有将近2000个左右的分区。 举一个案例来说明一下。 现在要做以下下几件事,要保证要宕机时间尽可能短。 为了方便起见,我暂定现在有4个DB instance,叫par01,par02,par03,par04. 1.需要对par01的数据运行Update语句,根据条件更新(update操作可能会移动分区), 2.然后把par01
jeanron100
2018/03/13
7690
Oracle优化08-并行执行
在讨论Oracle的性能问题时,通常要假设一个前提,那就是这个系统是OLTP还是OLAP(或者说数据仓库系统)。 只有在这个前提下,讨论一些性能问题才有意义,因为这两类系统太不一样了,甚至很多技术是相悖的。
小小工匠
2021/08/16
3780
点击加载更多

相似问题

Android测试模块(Gradle插件1.3):来自非默认maven存储库的依赖项

13

android studio中的插件gradle无法工作

10

Android Studio 1.3 -无法进行本机调试

23

Gradle android测试插件找不到测试

12

自定义android gradle插件无法加载类

13
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文