4

CXF を使用して保護された Web サービスを利用したいと考えています。(http://host:port/test/ws?wsdl)。以下は私のコードです。しかし、それは以下に示す例外を与えています。SoapUI で、Web サービスをテストしました。「aut」タブの下の SoapUI で資格情報を指定しました。それは働いていた。CXF を使用してセキュアな Web サービスを利用する方法を教えてください。

ProcessService proxy = new ProcessService(wsdlURL, SERVICE_NAME);       
try {       
  IProcessService port = proxy.getBinding1IProcessService();
  Client client = ClientProxy.getClient(port);
  HTTPConduit http = (HTTPConduit) client.getConduit();
  http.getAuthorization().setUserName("username");
  http.getAuthorization().setPassword("password");


  System.out.println("Result=" + port.startReturnDDCStatusForAC(""));
} catch (Exception e) {
 e.printStackTrace();
}

例外:

 Okt 09, 2012 7:23:50 PM org.apache.cxf.service.factory.ReflectionServiceFactoryBean buildServiceFromWSDL
    INFO: Creating Service {http://tempuri.org/}ProcessService from WSDL: http://sn000333.tauri.ch:61527/WS/Process?wsdl
    Okt 09, 2012 7:24:02 PM org.apache.cxf.ws.policy.AssertionBuilderRegistryImpl handleNoRegisteredBuilder
    WARNING: No assertion builder for type {http://schemas.microsoft.com/ws/06/2004/policy/http}BasicAuthentication registered.
    org.apache.cxf.ws.policy.PolicyException: None of the policy alternatives can be satisfied.
        at org.apache.cxf.ws.policy.EndpointPolicyImpl.chooseAlternative(EndpointPolicyImpl.java:165)
        at org.apache.cxf.ws.policy.EndpointPolicyImpl.finalizeConfig(EndpointPolicyImpl.java:145)
        at org.apache.cxf.ws.policy.EndpointPolicyImpl.initialize(EndpointPolicyImpl.java:141)
        at org.apache.cxf.ws.policy.PolicyEngineImpl.createEndpointPolicyInfo(PolicyEngineImpl.java:549)
        at org.apache.cxf.ws.policy.PolicyEngineImpl.getEndpointPolicy(PolicyEngineImpl.java:295)
        at org.apache.cxf.ws.policy.PolicyEngineImpl.getClientEndpointPolicy(PolicyEngineImpl.java:278)
        at org.apache.cxf.ws.policy.PolicyDataEngineImpl.getClientEndpointPolicy(PolicyDataEngineImpl.java:61)
        at org.apache.cxf.transport.http.HTTPConduit.updateClientPolicy(HTTPConduit.java:318)
        at org.apache.cxf.transport.http.HTTPConduit.<init>(HTTPConduit.java:303)
        at org.apache.cxf.transport.http.HTTPTransportFactory.getConduit(HTTPTransportFactory.java:250)
        at org.apache.cxf.binding.soap.SoapTransportFactory.getConduit(SoapTransportFactory.java:228)
        at org.apache.cxf.binding.soap.SoapTransportFactory.getConduit(SoapTransportFactory.java:235)
        at org.apache.cxf.endpoint.AbstractConduitSelector.getSelectedConduit(AbstractConduitSelector.java:103)
        at org.apache.cxf.endpoint.UpfrontConduitSelector.selectConduit(UpfrontConduitSelector.java:77)
        at org.apache.cxf.endpoint.ClientImpl.getConduit(ClientImpl.java:842)
        at com.test.TestWS.main(TestWS.java:66)

SOAPUI テスト:

aut tab の下で、以下の詳細を指定しましたが、機能しています。認証タイプ: プリエンプティブ ユーザー名: ユーザー名 パスワード: パスワード

4

1 に答える 1

0

HttpBasicAuthSupplierを拡張し、 getPreemptiveUserPassをオーバーライドすることで、独自のMyBasicAuthSupplierを作成できるかもしれません。次に、 setAuthSupplierメソッドを使用して、新しいクラスのインスタンスをHTTPConduitに設定できます

これはおそらくもっと便利でしょう。

http://alvinalexander.com/java/jwarehouse/apache-cxf/rt/transports/http/src/test/java/org/apache/cxf/transport/http/HTTPConduitTest.java.shtml

乾杯。

于 2012-10-10T08:08:18.407 に答える