Java 用于具有usernametoken配置文件的安全webservice的JAXWS Metro客户端
我想使用一个使用oasis风格用户名令牌配置文件(…)的Web服务 我可以使用CXF和Weblogic客户端,但我喜欢使用纯Metro客户端 你知道我怎么做吗 谢谢 CXF示例:Java 用于具有usernametoken配置文件的安全webservice的JAXWS Metro客户端,java,web-services,java-metro-framework,usernametoken,Java,Web Services,Java Metro Framework,Usernametoken,我想使用一个使用oasis风格用户名令牌配置文件(…)的Web服务 我可以使用CXF和Weblogic客户端,但我喜欢使用纯Metro客户端 你知道我怎么做吗 谢谢 CXF示例: serviceClientPort = clientFactory.buildClientPort(wsdlUrl,null); org.apache.cxf.endpoint.Client clientProxy = ClientProxy.getClient(serviceClientPort); org.a
serviceClientPort = clientFactory.buildClientPort(wsdlUrl,null);
org.apache.cxf.endpoint.Client clientProxy = ClientProxy.getClient(serviceClientPort);
org.apache.cxf.endpoint.Endpoint cxfEndpoint = clientProxy.getEndpoint();
Map<String, Object> outProps = new HashMap<String, Object>();
outProps.put(WSHandlerConstants.ACTION, WSHandlerConstants.USERNAME_TOKEN);
outProps.put(WSHandlerConstants.USER, "someuser");
outProps.put(WSHandlerConstants.PASSWORD_TYPE, WSConstants.PW_DIGEST);
outProps.put(WSHandlerConstants.PW_CALLBACK_CLASS,CapHardcodedPassProvider.class.getName());
WSS4JOutInterceptor wssOut = new WSS4JOutInterceptor(outProps);
cxfEndpoint.getOutInterceptors().add(wssOut);
serviceClientPort=clientFactory.buildClientPort(wsdlUrl,null);
org.apache.cxf.endpoint.clientProxy=clientProxy.getClient(serviceClientPort);
org.apache.cxf.endpoint.endpoint cxfEndpoint=clientProxy.getEndpoint();
Map outProps=new HashMap();
put(WSHandlerConstants.ACTION,WSHandlerConstants.USERNAME\u令牌);
put(wshandlerstants.USER,“someuser”);
outProps.put(WSHandlerConstants.PASSWORD\u类型,WSConstants.PW\u摘要);
put(WSHandlerConstants.PW_CALLBACK_类,CapHardcodedPassProvider.CLASS.getName());
WSS4JOutInterceptor wssOut=新的WSS4JOutInterceptor(输出程序);
cxfEndpoint.getOutiterCeptors().add(wssOut);
Weblogic客户端:
CallService callService = new CallService(wsdlUrl,CAP_QNAME);
CallServicePort port = callService.getCallServiceSoapPort(new WebServiceFeature[] { cpf });
BindingProvider bindingProvider = (BindingProvider) port;
Map<String, Object> rc = (Map<String, Object>) bindingProvider.getRequestContext();
List<CredentialProvider> credProviders = new ArrayList<CredentialProvider>();
credProviders.add(new ClientUNTCredentialProvider(USERNAME.getBytes(), PASSWORD.getBytes()));
CallService CallService=newcallservice(wsdlUrl,CAP_QNAME);
CallServicePort=callService.getCallServiceSoapPort(新WebServiceFeature[]{cpf});
BindingProvider BindingProvider=(BindingProvider)端口;
Map rc=(Map)bindingProvider.getRequestContext();
List credProviders=new ArrayList();
添加(新客户端UntCredentialProvider(USERNAME.getBytes()、PASSWORD.getBytes());
private void addUsernameTokenProfile(WebService webServicePort, String username, String password) {
try
{
final String SECURITY_NAMESPACE =
"http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd";
SOAPFactory soapFactory = SOAPFactory.newInstance();
QName securityQName = new QName(SECURITY_NAMESPACE, "Security");
SOAPElement security = soapFactory.createElement(securityQName);
QName tokenQName = new QName(SECURITY_NAMESPACE, "UsernameToken");
SOAPElement token = soapFactory.createElement(tokenQName);
QName userQName = new QName(SECURITY_NAMESPACE, "Username");
SOAPElement soapUsername = soapFactory.createElement(userQName);
soapUsername.addTextNode(username);
QName passwordQName = new QName(SECURITY_NAMESPACE, "Password");
SOAPElement soapPassword = soapFactory.createElement(passwordQName);
soapPassword.addTextNode(password);
token.addChildElement(soapUsername);
token.addChildElement(soapPassword);
security.addChildElement(token);
Header header = Headers.create(security);
((WSBindingProvider) webServicePort).setOutboundHeaders(header);
}}