我们有一个 Web 应用程序,它由向我们的前端开发团队公开的各种 Web 服务组成。我们是一家小商店,所以安全性从来不是我们关心的问题,但我们仍然想知道如何实施它。
我们使用的是 Netbeans 7.0.1、Glassfish 3.1.1 b12 和 SOAP。我们已经通过 Netbeans 中的向导配置了基本的安全性并使其正常工作。然后我们尝试添加传输安全性,并验证它已添加到 WSDL 文件中。当我们尝试添加 SSL 时,我们收到以下错误:
在服务器端:
严重:WSS1601:未满足安全要求 - 策略中配置了传输绑定,但传入消息未启用 SSL 严重:WSITPVD0035:验证入站消息中的安全性时出错。com.sun.xml.wss.impl.XWSSecurityRuntimeException:WSS1601:未满足安全要求 - 在策略中配置了传输绑定,但传入消息未在 com.sun.xml.wss.impl.policy.verifier.MessagePolicyVerifier.verifyPolicy( MessagePolicyVerifier.java:125) 在 com.sun.xml.ws.security.opt.impl.incoming.SecurityRecipient.createMessage(SecurityRecipient.java:983) 在 com.sun.xml.ws.security.opt.impl.incoming。 SecurityRecipient.validateMessage(SecurityRecipient.java:232) 在 com.sun.xml.wss.provider.wsit.WSITServerAuthContext.verifyInboundMessage(WSITServerAuthContext.java:586) 在 com.sun.xml.wss.provider。
在客户端:
09:36:16,464 警告 [org.apache.cxf.ws.security.wss4j.WSS4JInInterceptor] (http--127.0.0.1-443-1) 请求不包含安全标头,但这是一个错误。09:36:16,467 错误 [org.jboss.ejb3.invocation] (http--127.0.0.1-443-1) JBAS014134:组件 ActivityEJB 上的 EJB 调用失败,用于方法 public ja va.util.List com.enginsol.ActivityEJB。 getActivities(int):javax.ejb.EJBException:javax.xml.ws.soap.SOAPFaultException:org.jboss.as.ejb3.tx.CMTTxInterceptor.handleExceptionInOurTx(CMTTxInterceptor.java:166)的安全标头无效[jboss-as- ejb3-7.1.0.Final.jar:7.1.0.Final] 在 org.jboss.as.ejb3.tx.CMTTxInterceptor.invokeInOurTx(CMTTxInterceptor.java:230) [jboss-as-ejb3-7.1.0.Final. jar:7.1.0.Final] 在 org.jboss.as.ejb3.tx.CMTTxInterceptor.required(CMTTxInterceptor.java:304) [jboss-as-ejb3-7.1.0.Final. jar:7.1.0.Final] 在 org.jboss.as.ejb3.tx.CMTTxInterceptor.processInvocation(CMTTxInterceptor.java:190) [jboss-as-ejb3-7.1.0.Final.jar:7.1.0.Final]在 org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:288) [jboss-invocation-1.1.1.Final.jar:1.1.1.Final] 在 org.jboss.as.ejb3.component.interceptors.CurrentInvocationContextInterceptor .processInvocation(CurrentInvocationContextInterceptor.java:41) [jboss-as-ejb3-7.1.0.Final.jar:7.1.0.Final] at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:288) [jboss- invocation-1.1.1.Final.jar:1.1.1.Final] 在 org.jboss.as.ejb3.component.interceptors.LoggingInterceptor.processInvocation(LoggingInterceptor.java:59) [jboss-as-ejb3-7.1.0. Final.jar:7。1.0.Final] 在 org.jboss.invocation.InterceptorContext。
每个 Web 服务在 sun-ejb-jar.xml 中的保护方式基本相同:
<ejb>
<ejb-name>ActivityWS</ejb-name>
<webservice-endpoint>
<port-component-name>ActivityWS</port-component-name>
<login-config>
<auth-method>BASIC</auth-method>
</login-config>
<transport-guarantee>CONFIDENTIAL</transport-guarantee>
</webservice-endpoint>
</ejb>
我很确定证书设置已正确完成,因为我们已经清除了与缺少密钥库和错误密钥库密码相关的启动错误。此外,我们最近添加的 RESTful 服务运行良好(弹出用户名/密码对话框并通过 SSL 运行)。客户端和服务器最初都部署到 Glassfish,但我们创建了该服务的小型消费者并将其部署到 JBoss 7.1 以尝试排除 Glassfish 错误。
这是我们可以在 SO 上找到的最接近的答案,而 OP 给出的答案很模糊,所以我们仍然没有解决方案。Java Glassfish - 如何使用 SSL Web 服务?
更新:
我浏览并遵循了 Jim 发布的指南(http://www.ryandelaplante.com/2007/06/ssl-and-http-basic-authentication-with.html)并稍微调整了我的设置。我将安全角色添加到 sun-ejb-jar 并将角色允许注释添加到 Web 服务(以前,角色在 sun-application.xml 和另一个 ejb-jar.xml 中处理)。我们的服务是 EJB 端点,所以我浏览了指南中的相关信息,但仍然遇到相同的错误。