SOAPヘッダーをjavaに追加する方法
oracleのNO-.net Webサービスを利用するには、soapヘッダーを追加する必要があります。 javaでsoapヘッダーを追加するにはどうすればよいですか?
Authenticator.setDefault(new ProxyAuthenticator("username", "password"));
System.getProperties().put("proxySet", "true");
System.setProperty("http.proxyHost", "IP");
System.setProperty("http.proxyPort", "port");
proxy = new RegPresMed_Service(new URL("webservice")).getRegPresMed();
((BindingProvider) proxy).getRequestContext().put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY, "realwebservice");
((BindingProvider) proxy).getRequestContext().put("com.Sun.xml.ws.request.timeout", new Integer(60000));
((BindingProvider) proxy).getRequestContext().put(BindingProvider.USERNAME_PROPERTY, "webserviceUsername");
((BindingProvider) proxy).getRequestContext().put(BindingProvider.PASSWORD_PROPERTY, "webservicePassword");
これは必要ですか?
((BindingProvider) proxy).getRequestContext().put(BindingProvider.USERNAME_PROPERTY, "webserviceUsername");
((BindingProvider) proxy).getRequestContext().put(BindingProvider.PASSWORD_PROPERTY, "webservicePassword");
私の石鹸ヘッダーはこのようなものです:
<wsse:Security soapenv:mustUnderstand="1"
xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd">
<wsse:UsernameToken wsu:Id="UsernameToken-6"
xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd">
<wsse:Username>username</wsse:Username>
<wsse:Password
Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordText">password</wsse:Password>
<wsse:Nonce
EncodingType="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-soap-message-security-1.0#Base64Binary">randomnaumber==</wsse:Nonce>
<wsu:Created>dateCreated</wsu:Created>
</wsse:UsernameToken>
</wsse:Security>
私はやった、このチュートリアルに従ってください。たくさん助けます
Javadbからのコピーです(ダウンしているため)
http://informatictips.blogspot.pt/2013/09/using-message-handler-to-alter-soap.html
または
http://www.javadb.com/using-a-message-handler-to-alter-the-soap-header-in-a-web-service-client
これを機能させるのに苦労しました。そのため、ここに完全なソリューションを追加します。
私の目的は、このヘッダーをSOAPエンベロープに追加することです。
<soapenv:Header>
<urn:OTAuthentication>
<urn:AuthenticationToken>TOKEN</urn:AuthenticationToken>
</urn:OTAuthentication>
</soapenv:Header>
最初に
SOAPHeaderHandler
クラスを作成します。import Java.util.Set; import Java.util.TreeSet; import javax.xml.namespace.QName; import javax.xml.soap.SOAPElement; import javax.xml.soap.SOAPEnvelope; import javax.xml.soap.SOAPFactory; import javax.xml.soap.SOAPHeader; import javax.xml.ws.handler.MessageContext; import javax.xml.ws.handler.soap.SOAPHandler; import javax.xml.ws.handler.soap.SOAPMessageContext; public class SOAPHeaderHandler implements SOAPHandler<SOAPMessageContext> { private final String authenticatedToken; public SOAPHeaderHandler(String authenticatedToken) { this.authenticatedToken = authenticatedToken; } public boolean handleMessage(SOAPMessageContext context) { Boolean outboundProperty = (Boolean) context.get(MessageContext.MESSAGE_OUTBOUND_PROPERTY); if (outboundProperty.booleanValue()) { try { SOAPEnvelope envelope = context.getMessage().getSOAPPart().getEnvelope(); SOAPFactory factory = SOAPFactory.newInstance(); String prefix = "urn"; String uri = "urn:api.ecm.opentext.com"; SOAPElement securityElem = factory.createElement("OTAuthentication", prefix, uri); SOAPElement tokenElem = factory.createElement("AuthenticationToken", prefix, uri); tokenElem.addTextNode(authenticatedToken); securityElem.addChildElement(tokenElem); SOAPHeader header = envelope.addHeader(); header.addChildElement(securityElem); } catch (Exception e) { e.printStackTrace(); } } else { // inbound } return true; } public Set<QName> getHeaders() { return new TreeSet(); } public boolean handleFault(SOAPMessageContext context) { return false; } public void close(MessageContext context) { // } }
- ハンドラーをプロキシに追加します。 javax.xml.ws.Bindingのドキュメントによると、「返されたチェーンが変更された場合、新しいチェーンを使用してバインディングインスタンスを設定するには、
setHandlerChain
への呼び出しが必要です。」
Authentication_Service authentication_Service = new Authentication_Service(); Authentication basicHttpBindingAuthentication = authentication_Service.getBasicHttpBindingAuthentication(); String authenticatedToken = "TOKEN"; List<Handler> handlerChain = ((BindingProvider)basicHttpBindingAuthentication).getBinding().getHandlerChain(); handlerChain.add(new SOAPHeaderHandler(authenticatedToken)); ((BindingProvider)basicHttpBindingAuthentication).getBinding().setHandlerChain(handlerChain);
- ハンドラーをプロキシに追加します。 javax.xml.ws.Bindingのドキュメントによると、「返されたチェーンが変更された場合、新しいチェーンを使用してバインディングインスタンスを設定するには、
私は同じ問題に直面していたので、xmlns:wsu属性を削除することで解決しました。usernameTokenに追加しないでください。これもあなたの問題を解決します。