在Web服务中进行身份验证和授权的最佳方式是什么?

我正在开发一套Web服务,需要基于角色的访问控制.
使用metro – SOAP,简单的java没有EJB.

>我想一次验证用户,使用用户名和
密码,与数据库进行匹配.在随后的电话中.
>我想使用某种会话管理.可能是一些
会话ID,在登录时检索到客户端,全部呈现
调用.

至今:

>阅读 authentication using a database – 但我想要应用程序级验证;

>阅读application authentication with jax-ws – 但我不想每次做认证机制;
>我想我可以使用一个SOAP处理程序来拦截所有的消息,并且在执行器中执行授权控制,使用一些会话标识符令牌,该消息可以与保存在数据库中的标识符进行匹配,在登录Web方法.

编辑:

我还有一些问题:

>如何知道被调用的Web方法的名称?
>我应该使用什么样的令牌?
>如何在通话之间传递这个令牌?

编辑2

因为@ ag112答案:

我在使用Glassfish.

我使用WS-Policy和WS-Security对邮件进行加密和签名.使用相互证书身份验证.我想补充这种消息级别的应用程序之间的安全性,用户的认证和授权也在消息级别.

我只是开发服务,我几乎不知道客户端,只是他们可以用不同的语言创建.

在这一点上,我认为最重要的是做我需要做的,以验证和验证用户,我最容易的方式来实现客户端应用程序.

解决方法

@路易斯:这是我的输入.

针对您的问题的精确解决方案取决于您期望的Web服务客户端的类型,您是否可以控制Web服务客户端系统,应用程序服务器等…..但假设您没有对Web服务客户端的任何控制,你只是一个通过HTTP传输的SOAP消息,这里是可能的解决方案.

你当然可以执行会话管理和消息级别或传输级别的认证.这意味着您可以在SOAP消息中拥有会话令牌和身份验证令牌信息,也可以使用标准HTTP会话和HTTP身份验证机制.

当然,如果传输层是HTTP,传输层解决方案要简单得多,行业范围更广泛.对于消息级别,可以使用ws-security等ws规范.
您的每个Web服务请求都是由唯一HTTP URI标识的简单HTTP GET / POST.
通常在jax-ws地铁环境中,WSServlet是用于任何Web服务调用的入口servlet,并且最终将调用委托给正确的服务提供者实现类.由于您的应用程序将部署在Web服务器中,您可以利用J2ee Web容器提供的所有会话和身份验证功能.

由于您正在寻找基于角色的访问控制,因此我将使用标准的< web-resource-collection>在web.xml中指定您希望在特定HTTP URI的情况下使用哪个角色.您可以使用标准的JAAS登录模块,该模块可以进行身份​​验证,并使用角色填充JAAS主题.如果SOAP XML中提供了用户名/密码,则JAAS登录模块还可以搜索/解析SOAP XML以检索这些信息. JAAS / app服务器将自动创建auth令牌并将其存储为cookie,以便每个后续请求不需要再次通过身份验证过程.这就是所有的J2ee标准.你可以在互联网上找到很多帮助.请让我知道您的应用服务器,以便我可以为您提供更多详细信息.

如果您仍然想使用SOAP消息级会话管理,则认证&授权过程,然后为您提供更多详细信息,可以了解有关客户端的更多详细信息.

EDIT1:
根据您的进一步投入,这里是我更多的想法:
消息安全性即加密和签名需要发生每个消息在服务器和客户端之间传播.作为消息身份验证 – 您打算做一次,并向客户端发送会话令牌/身份验证令牌用于后续调用.

问题仍然存在:如果在第一次身份验证的SOAP响应中放置唯一会话标识符,您希望客户端解析SOAP响应XML,并确保客户端每次在随后的SOAP请求中向您发送会话标识符.
要么
您希望将会话管理保持为透明的客户端,并且客户端需要首先发送用户名/密码令牌,后续的呼叫不需要任何用户名/密码令牌.在这种情况下,您将需要依靠基于传输的会话管理. HTTP Cookie

现在最适合你的情况取决于你的用例.你能告诉我预期的用例流程是什么?另一个系统(Web服务客户端)如何对系统进行多个服务调用?是另一个系统用户驱动/一些后台进程?什么是确切的需要,您只想要第一个服务呼叫通过身份验证过程而不是后续呼叫?

PS:Glassfish服务器提供了一种配置消息认证提供程序的方式,可自动启用/禁用消息级认证.

EDIT2:
我明白你不想在客户端应用程序中存储用户凭据,Web服务器需要这些用户凭据.
OAuth是开放的标准协议,允许站点A访问站点B上的用户私有数据.最终的想法是站点A获得具有特定到期时间的认证令牌.因此,从用户凭据或jsession id加密的令牌可以帮助您避免重新认证.您只需要决定在客户端应用程序方面保持令牌的位置
如果传输是HTTP协议,则可以将令牌保存为cookie.

说过,每次传递用户凭据每次似乎都比较容易和直接.

java – JAX-WS,认证和授权 – 如何?的更多相关文章

  1. java – 使用JAX-WS更改运行时生成的WSDL中的schemaLocation和soap:address位置

    是否可以在JAX-WSWSDL中配置位置?当我部署下面的示例时,’servername’将是localhost,’serverport’将是Web应用程序的本地端口号.但是,我想将这些重新配置为代理服务器名称和重定向到服务的服务器端口.这是可能的,我将如何实现它?

  2. Java – 使用带有JAX-WS的动态客户端的优点

    使用带有JAX-WS服务的动态客户端与仅使用生成的客户端类相比有什么优势?**对于我的特定情况,我使用ApacheCXF,我不确定其他库允许“动态”客户端.–我想我不需要添加这个,但是……我正在寻找非显而易见的(我知道……

  3. java – 有没有人在Metro上本地解析schemaLocation的jax-ws-catalog.xml?

    解决方法你在哪里放置jax-ws-catalog.xml和WSDL文件?

  4. java – JAX-WS,认证和授权 – 如何?

    在Web服务中进行身份验证和授权的最佳方式是什么?>我应该使用什么样的令牌?>如何在通话之间传递这个令牌?是另一个系统用户驱动/一些后台进程?什么是确切的需要,您只想要第一个服务呼叫通过身份验证过程而不是后续呼叫?

  5. java – 使用JAX-WS在WebLogic中没有模式导入的单个WSDL

    如何使用JAX-WS配置WebLogic10.3.6生成的Web服务,以将对象模式包含在单个WSDL文件声明中,而不是导入声明?

  6. java – 我的jax-ws webservice客户端只返回空对象

    我有一个第三方Web服务,我使用wsimport生成一个客户端.每次对webservice的调用都会成功完成,但是我得到的响应对象的所有字段都设置为null.监视网络我可以看到,在线路上,响应消息中的所有XML元素都包含值,因此对象中应包含非空数据.此外,使用旧axis1生成并使用相同数据调用的相同服务的客户端返回非空响应.知道发生了什么事吗?

  7. java – 无法找到JAX-WS的Spring Namespace

    我想将JAX-WS集成到我的Spring项目中.找到此链接:http://jax-ws-commons.java.net/spring/我采用它并将其集成到我的applicationContext.xml:但每次启动Tomcat时,我都会遇到以下异常:SEVERE:Exceptionsendingcontextinitializedeventtolistenerinstanceofclassorg

  8. java – jax-ws将内容类型更改为Content-Type,因为服务器超级敏感

    我必须连接到只能理解Content-Type而不是Content-type的执行不良的服务器.如何让我的JAX-WS客户端发送Content-Type?

  9. java – JAX-WS总是内联发送MTOM附件

    基本上我想创建一个Web服务客户端通过代理方法发送一个mtomsoap消息.我已经从Web服务wsdl创建了我的服务工件.消息已正确创建,但是当我启用mtom并添加附件时,附件始终是内联发送的,而不是单独的mime部分.它像mtom是启用,但由于某种原因它决定不优化消息,所以发送它内联.通过soapui运行相同的代码给出正确的结果,所以我知道服务本身将接受它.这是我创建一个soap请求并发送它的基

  10. java – 使用JAX-WS 2.0和@WebService发布具有一个服务的多个端口

    我想创建一个暴露的多个端口类型的SOAP服务,其中每个端口类型都有一个单独的接口.我正在尝试使用JAX-WS2.0.例:我遇到的问题是@WebService是使用单个类/接口来定义的,所以我能够设置的唯一方法是具有两个单独的服务.每个服务由具有@WebService注释的单独类实现.我想使用相同的服务公开两个端口,以便清楚地表明它们都是同一个API的一部分.这可能吗?

随机推荐

  1. 基于EJB技术的商务预订系统的开发

    用EJB结构开发的应用程序是可伸缩的、事务型的、多用户安全的。总的来说,EJB是一个组件事务监控的标准服务器端的组件模型。基于EJB技术的系统结构模型EJB结构是一个服务端组件结构,是一个层次性结构,其结构模型如图1所示。图2:商务预订系统的构架EntityBean是为了现实世界的对象建造的模型,这些对象通常是数据库的一些持久记录。

  2. Java利用POI实现导入导出Excel表格

    这篇文章主要为大家详细介绍了Java利用POI实现导入导出Excel表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. Mybatis分页插件PageHelper手写实现示例

    这篇文章主要为大家介绍了Mybatis分页插件PageHelper手写实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  4. (jsp/html)网页上嵌入播放器(常用播放器代码整理)

    网页上嵌入播放器,只要在HTML上添加以上代码就OK了,下面整理了一些常用的播放器代码,总有一款适合你,感兴趣的朋友可以参考下哈,希望对你有所帮助

  5. Java 阻塞队列BlockingQueue详解

    本文详细介绍了BlockingQueue家庭中的所有成员,包括他们各自的功能以及常见使用场景,通过实例代码介绍了Java 阻塞队列BlockingQueue的相关知识,需要的朋友可以参考下

  6. Java异常Exception详细讲解

    异常就是不正常,比如当我们身体出现了异常我们会根据身体情况选择喝开水、吃药、看病、等 异常处理方法。 java异常处理机制是我们java语言使用异常处理机制为程序提供了错误处理的能力,程序出现的错误,程序可以安全的退出,以保证程序正常的运行等

  7. Java Bean 作用域及它的几种类型介绍

    这篇文章主要介绍了Java Bean作用域及它的几种类型介绍,Spring框架作为一个管理Bean的IoC容器,那么Bean自然是Spring中的重要资源了,那Bean的作用域又是什么,接下来我们一起进入文章详细学习吧

  8. 面试突击之跨域问题的解决方案详解

    跨域问题本质是浏览器的一种保护机制,它的初衷是为了保证用户的安全,防止恶意网站窃取数据。那怎么解决这个问题呢?接下来我们一起来看

  9. Mybatis-Plus接口BaseMapper与Services使用详解

    这篇文章主要为大家介绍了Mybatis-Plus接口BaseMapper与Services使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  10. mybatis-plus雪花算法增强idworker的实现

    今天聊聊在mybatis-plus中引入分布式ID生成框架idworker,进一步增强实现生成分布式唯一ID,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部