axis-java-user mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From Martin Gainty <mgai...@hotmail.com>
Subject RE: Exception : org.apache.axis2.AxisFault: <faultstring>Missing wsse:Security header in request</faultstring>
Date Thu, 11 Apr 2013 10:20:38 GMT
wsse:Security from Rampart is implented by wss4j

http://www.ibm.com/developerworks/webservices/library/ws-Axis2/

for specific examples of KeyIdentifier 
http://coheigea.blogspot.com/2013/03/signature-and-encryption-key.html
 
Viel Gluck

______________________________________________ 
Verzicht und Vertraulichkeitanmerkung

Diese Nachricht ist vertraulich. Sollten Sie nicht der vorgesehene Empfaenger sein, so bitten
wir hoeflich um eine Mitteilung. Jede unbefugte Weiterleitung oder Fertigung einer Kopie ist
unzulaessig. Diese Nachricht dient lediglich dem Austausch von Informationen und entfaltet
keine rechtliche Bindungswirkung. Aufgrund der leichten Manipulierbarkeit von E-Mails koennen
wir keine Haftung fuer den Inhalt uebernehmen.

  




Date: Thu, 11 Apr 2013 00:46:01 -0700
From: taniamm2002@yahoo.com
Subject: Exception : org.apache.axis2.AxisFault: <faultstring>Missing wsse:Security
header in request</faultstring>
To: java-user@axis.apache.org



Hello I keep on getting the following exception: 
 
 
 
org.apache.axis2.AxisFault: <faultstring>Missing wsse:Security header in request</faultstring>

 
at org.apache.axis2.util.Utils.getInboundFaultFromMessageContext(Utils.java:536)

at org.apache.axis2.description.OutInAxisOperationClient.handleResponse(OutInAxisOperation.java:375)

at org.apache.axis2.description.OutInAxisOperationClient.send(OutInAxisOperation.java:421)

at org.apache.axis2.description.OutInAxisOperationClient.executeImpl(OutInAxisOperation.java:229)

at org.apache.axis2.client.OperationClient.execute(OperationClient.java:165)

at axis2wstest.TestfnStub.testws(TestfnStub.java:198)

at axis2wstest.testwscl.main(testwscl.java:60)
 
 
 
Here is what I do:
  
  1. I created Dynamic Web Project- with name testfn
 
    2. I added two files:
         
     PWCBHANdler.java    (code is bellow)
          
        package axis2wstest;    
 
        import java.io.IOException;

        import javax.security.auth.callback.Callback;
        import javax.security.auth.callback.CallbackHandler;
        import javax.security.auth.callback.UnsupportedCallbackException;
        
import org.apache.ws.security.WSPasswordCallback;

 
         public class PWCBHandler implements CallbackHandler{
 
 
           public void handle(Callback[] callbacks)  throws  IOException, UnsupportedCallbackException

           {
 for(int i = 0; i < callbacks.length;i++)
  
                 { 
WSPasswordCallback pwcb = (WSPasswordCallback)callbacks[i];
       
                   if (pwcb.getIdentifier().equals("test") && pwcb.getPassword().equals("pass"))

  
                   {
   
                       return;
        
                   }
  
                 
                   else
  
                   {
    
                      throw new UnsupportedCallbackException(callbacks[i],"Incorrect login/password");
  
                   }
  
                 }
  
                }
              
}
 
   
 
      AND   testfn.java      (code is bellow) 
       
       public class testfn {
 
 public  int testws(int x)
 { 
  return 2*x;
 }
 
      }

       
    3. I click on my source file (testfn.java)-> New - Web Sercie;

    4. I downloaded rampart and copied all the jar files from lib directory of rampart distribution
to testfn/WebContent/WEB- INF/lib directory.
    5. I changed the testfn/WEB_INF/services/testfn/META_INF/ services.xml (engaged rampart
module:
and added policy:
 
<wsp:Policy wsu:Id="UsernameToken" xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd"
      xmlns:wsp="http://schemas.xmlsoap.org/ws/2004/09/policy">
  <wsp:ExactlyOne>
    <wsp:All>
      <sp:TransportBinding xmlns:sp="http://schemas.xmlsoap.org/ws/2005/07/securitypolicy">
       <wsp:Policy>
        <sp:TransportToken>
         <wsp:Policy>
           <sp:HttpToken RequireClientCertificate="false"/>
        </wsp:Policy>
     </sp:TransportToken>
    <sp:AlgorithmSuite>
<wsp:Policy>
<sp:Basic256/>
</wsp:Policy>
</sp:AlgorithmSuite>
</wsp:Policy>
</sp:TransportBinding>
<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%22/>
</wsp:Policy>
</sp:SupportingTokens>
<ramp:RampartConfig xmlns:ramp="http://ws.apache.org/rampart/policy">
<ramp:passwordCallbackClass>axis2wstest.PWCBHandler</ramp:passwordCallbackClass>
</ramp:RampartConfig>
</wsp:All>
</wsp:ExactlyOne>
</wsp:Policy>
 
 
   6. I ran my web service on my localhost
 
   7. Created web - service client
     and here is my testclint.java
 
public static void main(String[] args) throws RemoteException {
        ConfigurationContext ctx;
        ctx = ConfigurationContextFactory.createConfigurationContextFromFileSystem("C:/Users/gismo2/workspace/testfnclient/WebContent/WEB-INF",
null);
        TestfnStub stub = new TestfnStub(ctx);
        Testws cl = new Testws();
        cl.setX(5);
        ServiceClient client = stub._getServiceClient();
        client.engageModule("rampart");     
        Options o = client.getOptions();
        o.setPassword("pass");
        o.setUserName("test");
        System.setProperty("javax.net.ssl.trustStore", "/path/to/server.jks");
        System.setProperty("javax.net.ssl.trustStorePassword", "password");
        TestwsResponse resp = stub.testws(cl);
        System.out.println("Response" + resp.get_return()); 		 	   		  
Mime
View raw message