阿里、蚂蚁、晟腾、中科加禾精彩分享 AI 基础设施洞见,现购票可享受 9 折优惠 |AICon 了解详情
写点什么

访谈与书摘:Masoud Kalali 的《GlassFish 安全》

  • 2011-02-03
  • 本文字数:2335 字

    阅读完需:约 8 分钟

Masoud Kalali 编著的《GlassFish 安全》涵盖的内容有:Java EE 安全模型;如何在Java EE 应用中设计开发安全的Web、EJB 模块,并将它们部署到 GlassFish 服务器环境中。Masoud 在书里还详细介绍了 GlassFish 应用服务器和 OpenDS 目录服务器的安装及配置,OpenDS 主要用来实现基于轻量级目录访问协议(LDAP)的用户认证和授权。

本书还介绍了用 OpenSSO 框架实现单点登录(SSO)的解决方案,其中包括用 RESTful Web Services 对用户进行认证和授权、通过 OpenSSO 解决方案确保 Java EE 应用和 Web Services 的安全。

InfoQ 就此书对 Masoud 进行了采访,和他讨论了写作动机、Java EE 6 里的安全新特性及其他一些话题。此外,InfoQ 还为读者准备了本书的书摘(第三章:设计、开发安全的Java EE 应用;778 KB 的PDF)。

InfoQ:你为什么编写这本书呢?

Masoud Kalali:写这本书的原因有很多,但最主要的还是以下几点:

开发人员清晰地理解安全、尤其是 Java EE 安全是很重要的,这就是写这本书最重要的原因。我认为对 Java EE 领域的开发人员来说,掌握 Java EE 安全的基础知识至关重要,所以在书里我用简单却详尽的方式对安全进行了阐述。

另一方面,GlassFish 是一款优秀的应用服务器产品,要在生产环境中使用 GlassFish,理解它的安全机制是很有必要的。

最后就是想用比参考文档更容易理解的方式,向那些对安全感兴趣的开发人员介绍 Java EE 6 引入的安全新特性。

InfoQ:对 Java EE 6 引入的安全新特性,你是怎么看的?

Masoud:和 Java EE 的其他服务、组件相比,安全并没有太多的变化。EJB 和 Web 层在 Java EE 5 和 Java EE 6 里都有非常大的变化,再看看安全,尽管 Java EE 6 在平台安全方面添加了一些新鲜气息,但我觉得我们仍然有进步的空间。

InfoQ:Web 层组件 Servlet 现在可以通过声明(@ServletSecurity 注解)和编程方式(HTTPServletRequest 接口增加的 login 和 authenticate 方法)支持认证。你如何看待 Web 层提供的这种安全支持?

Masoud:现在的开发和部署都从 XML 描述符转向了注解,增加注解符合这一趋势。但编程方式的安全增强则更有意思一些,login、logout 这些方法能让开发人员更好地控制认证和授权过程。很高兴 Java EE 平台能有更好的安全特性。

InfoQ:和 Spring 安全 3 等其他安全框架相比,Java EE 6 里的安全新特性怎么样?

Masoud:我觉得不能简单地把 Java EE 平台安全和 Spring 安全放在一起比较,顾名思义,前者是平台级的,后者只是基于平台构建、处理更细粒度需求的框架。当我们通盘使用 Spring 框架,或者软件架构师确信系统不需要十分细致的安全集成方案时,使用 Spring 安全就可以了。

Java EE 平台提供的安全机制无法满足需求的时候,我倾向于使用 OpenSSO 之类的产品,OpenSSO 不仅能非侵入式地和 Java 应用集成,还可以让 Java 应用从本地或通过 RESTful 接口调用其他编程语言,从而使用相同的基础设施。

InfoQ:安全相关的其他 JSR 是怎样和 Java 安全模型保持一致的呢?比如 JASPIC(Java Authentication Service Provider Interface for Containers, JSR 196 )和 JACC(Java Authorization Contract for Containers, JSR 115 )。

Masoud:众所周知,产品的可插拔性和扩展性在产品需要添加新特性的时候非常有用。我们发现,当产品 A 支持的契约接口同样被其他类似产品支持的时候,可插拔性会更加重要。

JSR-196 和 JSR-115 这两个规范提供的大纲和契约接口统一了 Java EE 应用服务器的认证和授权模型。

JSR-196 的目标对象不是应用开发人员,而是框架和安全产品的开发人员,因为它能简化不同认证模型和 Java EE 应用服务器之间的集成。使用 JSR-196 SPI,开发人员可以开发自己的认证模块、把该模块插入应用服务器、对认证模块进行配置,并拦截服务器和客户端之间传输的消息。可以在四个点进行消息拦截:

  1. 客户端,请求发送给服务器之前。
  2. 服务器端,目标服务接受客户端请求之前。
  3. 服务器端,给客户端返回响应之前。
  4. 客户端,处理服务器响应之前。

消息拦截的使用示例可以参看 GlassFish 应用服务器的消息安全, Metro Web Services 框架就是利用消息拦截提供了容易配置、容易管理的 Web Services 安全。

JSR-196 的另一个应用场景是把 OpenID 等“none-supported”的认证模型集成到应用服务器当中,然后在部署到应用服务器里的应用中使用这些认证模型。

我们一提到安全,首先想到的两件事情就是认证和授权,正如我前面所说的,JSR-196 为 Java EE 应用服务器提供了统一的验证机制。JSR-115 提出的 SPI 则允许模块开发人员用自己的逻辑定义主体、定义角色、检查主体是否具有特定的角色,从而为支持 JSR 的 Java EE 应用服务器增加新的授权模型。

InfoQ:你希望 Java EE 后续的版本中能增加哪些安全特性呢?

Masoud:我希望能让开发人员更自由地控制整个认证和授权过程,不论使用缺省配置还是使用自己的配置和定制。目前,有些框架有专门的安全层,比如 Seam ;还有些框架给开发人员提供了很不错的安全方法定制,比如 Spring 安全;我期望能有一些基于角色的访问控制,也期望 SSO 能更加广泛地应用。OpenSSO、Oracle 访问管理器、IBM Tivoli 访问管理器等访问管理产品现在都开始支持刚刚提到的这些功能、以及很多其他的安全集成特性了。

InfoQ:谢谢你接受我们的采访。最后一个问题,你喜欢的 IT 类图书和非 IT 类图书分别是什么?

Masoud:说到 IT 类图书,我喜欢《大型软件体系结构:使用UML 实践指南》,最喜欢的非IT 类图书则是《魔戒》系列。

查看英文原文: Interview and Book Excerpt: Masoud Kalali’s GlassFish Security


感谢王丽娟对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家加入到 InfoQ 中文站用户讨论组中与我们的编辑和其他读者朋友交流。

2011-02-03 00:001531

评论

发布
暂无评论
发现更多内容

干货|成为优秀软件测试工程师的六大必备能力

SoFlu软件机器人

小令观点 | 不希望我的身份被别人冒用,该怎么办呢?

令牌云数字身份

网络安全 人脸识别 芯片技术

移动开发跨平台框架,你了解多少?

FinClip

火山引擎边缘云荣获2022全球分布式云大会两项大奖

火山引擎边缘云

云原生 边缘计算 边缘云 火山引擎边缘计算

API网关与南北向安全设计

阿泽🧸

API网关 12月月更

App长登录思考与实现

石君

信息安全 APP开发 认证

RocketMQ 全链路灰度探索与实践

Apache RocketMQ

RocketMQ 服务端 灰度

2023免费双系统虚拟机软件CrossOver2023

茶色酒

crossover CrossOver2023

照亮无尽前沿之路:华为正成为科技灯塔的守护者

脑极体

Web Development Technology Trends for 2023

Mahipal_Nehra

UI UX AI Codec Metaverse

国产智能BI产品崛起,帆软Fine BI、瓴羊Quick BI等应该如何选择

小偏执o

腾讯云NoSQL数据库产品2022再迎升级,多项技术细节首次公开

科技热闻

数据治理:指标体系管理

用友BIP

国产自研、安全、高可用——袋鼠云大数据基础平台EasyMR筑基企业数字化转型

袋鼠云数栈

大数据 hadoop 数据中台 基础数据平台 12 月 PK 榜

TitanIDE引领企业开发工具变革

行云创新

ide CloudIDE WebIDE

互联网都在说降本增效,小红书技术团队是怎么做的?

小红书技术REDtech

5.外包学生管理系统实战

程序员小张

「架构实战营」

NTFS读写工具Tuxera for Mac2023下载及功能介绍

茶色酒

Tuxera2022 Tuxera NTFS2022 Tuxera NTFS Mac2022

内部CRM和商业化SAAS CRM的区别

久歌

SaaS 架构设计 CRM

服务超80家金融行业头部企业,腾讯会议将支持混合云部署

科技热闻

NFTScan 与 Merlin Protocol 达成战略合作伙伴,双方将在 NFT 数据层面展开深度合作

NFT Research

NFT 数据基础设施

Istio的使用场景

穿过生命散发芬芳

istio 12月月更

空间节省50%,时序性能提升5倍,三一重工从Hadoop+Spark到MatrixDB架构变迁实现One for ALL

YMatrix 超融合数据库

三一重工 超融合数据库 数据库· YMatrix

腾讯智慧农业首次亮相,助力青海大通农产品走进大湾区

科技热闻

Wallys//QCN9074/QCN9024/WiFi6/WiFi6E/4x4 MU MIMO Dual Band WiFi Module MiniPCIe/industrial wifi6 moudle

wallysSK

QCN9074 QCN9024 QCN9072

量化合约对冲交易机器人app系统开发源代码部署

开发微hkkf5566

爱奇艺:基于龙蜥与 Koordinator 在离线混部的实践解析 | 龙蜥技术

OpenAnolis小助手

开源 cpu 爱奇艺 混部 龙蜥操作系统

Flask上手:step by step

无人之路

flask web开发 Web应用开发 Python. python web

声网王浩宇:RTE 场景下的 Serverless 架构挑战【RTE 2022】

声网

架构 实时互动

iOS 15 TableView willDisplayCell获取失败

刿刀

UITableView iOS16

使用 JS 转换数据的最佳实践

夏木

typescript data-convert

访谈与书摘:Masoud Kalali的《GlassFish安全》_Java_Srini Penchikala_InfoQ精选文章