【发布时间】:2010-10-10 02:05:41
【问题描述】:
我正在设置一个带有单个 EJB3 的 glassfish 服务器作为 POC 的模拟后端。在我添加一些基本身份验证之前,一切都运行良好。只需计划文本用户名和密码,这项工作没有什么复杂的。我在 EJB 中添加了以下注释:
@WebService(name = "Banking", serviceName = "Banking", targetNamespace = BANKING_NAMESPACE)
@DeclareRoles("user")
@Stateless
public class Banking {
...
@RolesAllowed("user")
@SOAPBinding(parameterStyle = ParameterStyle.BARE)
@WebMethod(action = BANKING_NAMESPACE + "/logon", operationName = "logon")
@WebResult(targetNamespace = XmlStrings.BANKING_MODEL_NAMESPACE)
public LogonResponse logon(@WebParam(targetNamespace = XmlStrings.BANKING_MODEL_NAMESPACE) Logon request) throws WebServiceException {
...
}
}
根据我对 EJB3 规范的阅读,这对于执行 SOAP Web 服务是很常见的。
但是当我发送这个 xml 时:
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:mod="http://www.dhcbank.com/banking/model">
<soapenv:Header>
<wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd">
<wsse:UsernameToken wsu:Id="UsernameToken-79" xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd">
<wsse:Username>fred</wsse:Username>
<wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordText">fred</wsse:Password>
</wsse:UsernameToken>
</wsse:Security>
</soapenv:Header>
<soapenv:Body>
<mod:logon/>
</soapenv:Body>
</soapenv:Envelope>
我收到以下错误作为 SOAP 错误:
java.lang.Exception: Client not authorized for invocation of public com.dhcbank.www.banking.schema.LogonResponse com.dhcbank.www.banking.Banking.logon(com.dhcbank.www.banking.schema.Logon) throws javax.xml.ws.WebServiceException
在 glassfish 日志中:
[#|2010-10-10T12:49:27.497+1100|INFO|glassfish3.0.1|javax.enterprise.system.core.security|_ThreadID=41;_ThreadName=http-thread-pool-8080-(2);|JACC Policy Provider: Failed Permission Check, context(BankingEAR/Banking_war_internal)- permission((javax.security.jacc.EJBMethodPermission Banking logon,ServiceEndpoint,com.dhcbank.www.banking.schema.Logon))|#]
在 glassfish 管理屏幕中,我添加了一个名为 fred 的用户,其密码为 fred,并将其分配给名为 user 的组。但这没有用。
我做了更多阅读,建议我创建一个 sun-ejb-jar.xml 文件并将其添加到 ear 文件中。所以我用这个内容创建了它:
<sun-ejb-jar>
<enterprise-beans>
<ejb>
<ejb-name>Banking</ejb-name>
<webservice-endpoint>
<port-component-name>Banking</port-component-name>
<login-config>
<auth-method>BASIC</auth-method>
<realm>file</realm>
</login-config>
</webservice-endpoint>
</ejb>
</enterprise-beans>
</sun-ejb-jar>
据我所知,这是正确的。但是我找不到任何告诉我port-component-name 元素的值应该是什么的东西。所以我不知道我是否做对了。
安全性似乎仍然无法正常工作,我无法弄清楚原因。有没有人有这方面的经验,可以指出我做错了什么或没有做什么?
【问题讨论】:
标签: web-services authentication soap glassfish ejb-3.0