2017-06-22 48 views
0

我正在使用Jboss EAP 7編寫一個代碼優先的Web服務,並且需要爲用戶名令牌驗證實現WS-Security ...爲此,我使用Apache CXF策略,我設法使一切工作在契約優先的角度,現在我需要使其作爲代碼優先的角度來工作的唯一方法是將策略包含到生成的wsdl中......爲此,我使用@org .apache.cxf.annotations.Policy,但該策略的代碼片段不會添加到Jboss生成的最終wsdl中。apache CXF @Policy不包括在WSDL中

這裏是我的代碼:

... 
    @WebService(serviceName = "ExampleService", portName = "ExampleService", 
     endpointInterface = "com.company.webservice.ExampleService", 
     targetNamespace = "https://service.company.com/company-ws/ExampleService") 
    @EndpointConfig(configFile = "WEB-INF/jaxws-endpoint-config.xml", 
     configName = "Custom WS-Security Endpoint") 
    @Policy(uri = "WEB-INF/company-username-token-policy.xml") 
    public class ExampleServiceImpl implements ExampleService { ... 

這裏是WEB-INF /公司用戶名令牌,則policy.xml

<?xml version="1.0" encoding="UTF-8" ?> 
<wsp:Policy wsu:Id="UsernameTokenPolicy" xmlns:wsp="http://www.w3.org/ns/ws-policy" 
    xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd"> 
    <wsp:ExactlyOne> 
     <wsp:All> 
      <sp:SupportingTokens 
       xmlns:sp="http://docs.oasis-open.org/ws-sx/ws-securitypolicy/200702"> 
       <wsp:Policy> 
        <sp:UsernameToken 
         sp:IncludeToken="http://docs.oasis-open.org/ws-sx/ws-securitypolicy/200702/IncludeToken/AlwaysToRecipient"> 
         <wsp:Policy> 
          <sp:WssUsernameToken11 /> 
         </wsp:Policy> 
        </sp:UsernameToken> 
       </wsp:Policy> 
      </sp:SupportingTokens> 
     </wsp:All> 
    </wsp:ExactlyOne> 
</wsp:Policy> 

我的JBoss部署,structure.xml有這些項已經:

<module name="org.apache.ws.security" export="true" /> 
<module name="org.apache.cxf" export="true" /> 
<module name="org.apache.cxf.impl" export="true" /> 

我在這裏錯過了什麼?

回答

0

想通了這個問題...

首先:你需要把政策的xml文件到資源文件夾而不是WEB-INF。

二:你需要添加placement = Policy.Placement.BINDING到您的@Policy批註......

@Policy(uri = "company-username-token-policy.xml", placement = Policy.Placement.BINDING)