使用 WS-Trust 与 Axis2 进行 WCF 互操作

发布于 2024-07-18 02:59:16 字数 233 浏览 14 评论 0原文

我们正在尝试使用 STS 颁发的 SAML 令牌让 WCF 和 Java 相互通信。 尽管双方都遵守 WS-Security、WS-Trust、WS-Policy 等标准,但它们似乎并没有相互交谈,并且其中一方会抛出神秘的异常或忽略安全标头。

我们在 MS 端使用 .NET 3.5、WCF Federation 绑定,在 java 端使用 Axis2/Rampart/Rahas。

有没有人能够做到这一点?

We are trying to get WCF and Java talking to each other using SAML tokens issued from an STS. Despite the fact that both sides are compliant with the standards, WS-Security, WS-Trust, WS-Policy, etc., they don't seem to talk to each other and one or the other will throw cryptic exceptions or ignore security headers.

We are using .NET 3.5, WCF Federation binding on the MS side, and Axis2/Rampart/Rahas on the java side.

Has anyone ever been able to make this work?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

情痴 2024-07-25 02:59:16

Axis2 在 WS 标准合规性方面并不完整。

我最近(上个月)经历了一个 POC 阶段,Axis2 未能通过我的 WS-* 合规性测试(特别是 WS-AT、WS-Coordination)。

看看“地铁计划”。 Sun 和 Microsoft 合作,让 WCF 和 JAX-WS 互操作“正确”。
https://metro.dev.java.net/

Axis2 is incomplete in terms of WS standards compliance.

I recently (in the last month) went through a POC phase where Axis2 failed my WS-* compliance tests (specifically WS-AT, WS-Coordination).

Have a look at "Project Metro". Sun and Microsoft collaborated on getting WCF and JAX-WS interop "right".
https://metro.dev.java.net/

迷迭香的记忆 2024-07-25 02:59:16

如果可以的话,我也不建议在 Java 方面使用 Axis2。 显然,使用 Glassfish 或 JAX-WS 会更容易,尽管我从未测试过它。

当我试图让 WCF 和 Axis2 合作时,我也遇到了这类问题。 检查 WSDL 文件中使用的标准版本,这些版本与我们的案例不匹配。

I would also not recommand going for Axis2 on the Java side, if you can. Would be easier with Glassfish or JAX-WS apparently, althoug I never tested it.

I ran into those kind of issues as well when trying to make WCF and Axis2 cooperate. Check the version of the standard used in the WSDL file, those were not matching in our case.

高跟鞋的旋律 2024-07-25 02:59:16

我假设服务器端是轴,尚不清楚,但这是更常见的。

如果您正在使用 Java 编写可互操作的 Web 服务,则应该考虑切换到 JAX-WS,不仅因为 axis2 编程模型有点奇怪,而且代码通常不完整。 我之前确实遇到过部分实现的功能,而且我发现很难确定使用 Microsoft 堆栈执行了哪些互操作性测试。

我想说您将来使用 JAX-WS 堆栈会有更好的机会。 一个主要原因是 Sun 工程师花了相当多的时间与 Microsoft 工程师坐在一起,以确保他们的堆栈具有互操作性,并且他们以相同的方式解释规范。 除此之外,编程模型更容易并且可以通过注释来驱动。 它还在一定程度上简化了部署和维护。 用于服务 .AAR 文件的附加容器以及从服务端点删除 axis2 的操作可以被忽略:端点可以被视为 Servlet。

有文档说明人们如何使用 SAML 来使用 JAX-WS:http://www.jroller。 com/gmazza/entry/using_the_opensaml_library_in

如果您无法摆脱 axis2,我认为需要采用类似的策略。 您将在其中拦截令牌并在调用服务端点之前进行身份验证。

请参阅:http://www.omg.org/news/会议/workshops/Web_Services_USA_Manual/02-3_K_Smith.pdf

http://www.mail-archive.com/[电子邮件受保护]/msg10292.html

http://www2.sys-con.com/ITSG /virtualcd/WebServices/archives/0303/secrist/index.html

I'm assuming that the server side is axis, it's not clear but that is more common.

If you are programming interoperable webservices you in Java you should consider switching to JAX-WS, not only because the axis2 programing model is a little bizarre, but often the code is incomplete. I've certainly come across features partially implemented before, also it's I found it difficult to determine what testing for interoperability had been performed with the Microsoft stack.

I would say you have much better chances in the future using a JAX-WS stack. One major reason is Sun Engineers spend quite some time sitting with Microsoft engineers to make sure their stacks were interoperable and they'd interpreted the specs in the same way. Besides this the programming model is easier and can be driven with annotations. It also somewhat simplifies deployment and maintenance. The additional container for servicing .AAR files and the fiddling to remove axis2 from the service endpoint can just be ignored: the endpoint can just be treated as a Servlet.

There is documentation of people getting SAML to work with JAX-WS: http://www.jroller.com/gmazza/entry/using_the_opensaml_library_in

If you cannot move away from axis2 I think a similar strategy needs to be employed. Where you would intercept the token and do the authentication before it gets to call the service endpoint.

See: http://www.omg.org/news/meetings/workshops/Web_Services_USA_Manual/02-3_K_Smith.pdf

http://www.mail-archive.com/[email protected]/msg10292.html

http://www2.sys-con.com/ITSG/virtualcd/WebServices/archives/0303/secrist/index.html

雪落纷纷 2024-07-25 02:59:16

我们已经在客户端和服务器端使用 WCF 成功测试了 Rampart 的 WS-Trust 场景。

BTW Rampart 尚不支持 WS-Federation 方案,您的安全策略可能与其相关。 [仅供参考 - WS-Federation 将于明年年中随 Rampart 一起提供]。

如果可以的话,请附上安全策略,我们可以仔细查看。

We have successfully tested Rampart for WS-Trust scenarios with WCF both at the client and server ends.

BTW Rampart doesn't have WS-Federation scenarios supported yet and your security policy could be related to it. [FYI - WS-Federation will be available with Rampart mid next year].

If you can please attach the security policies we can have a close look..

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文