CXF调用webservice跳过https认证

1、相关依赖

powershell 复制代码
compile ('org.apache.cxf:cxf-spring-boot-starter-jaxws:3.5.5')

2、添加配置

java 复制代码
package com.tele.health.operation.api.listener;


import org.apache.cxf.configuration.jsse.TLSClientParameters;
import org.apache.cxf.transport.http.HTTPConduit;
import org.apache.cxf.transport.http.HTTPConduitConfigurer;
import org.apache.cxf.transports.http.configuration.HTTPClientPolicy;
import org.springframework.context.annotation.Configuration;
import javax.net.ssl.*;
import java.security.KeyManagementException;
import java.security.NoSuchAlgorithmException;
import java.security.cert.CertificateException;

@Configuration
public class SoapHTTPConduitConfigurer implements HTTPConduitConfigurer {

        public void configure(String name, String address, HTTPConduit c) {

            try{

                HTTPClientPolicy httpClientPolicy = new HTTPClientPolicy();
//                httpClientPolicy.setConnectionTimeout(itfConfig.getConnectionTimeout());
//                httpClientPolicy.setReceiveTimeout(itfConfig.getSoTimeout());
                c.setClient(httpClientPolicy);
                SSLContext context = createIgnoreVerifySSL();
                TLSClientParameters params = c.getTlsClientParameters();
                if (params == null) {
                    params = new TLSClientParameters();
                }

                params.setSslContext(context);
                //SSLConnectionSocketFactory ssf = new SSLConnectionSocketFactory(context,
                 //       new String[] { "SSLv3", "TLSv1", "TLSv1.1", "TLSv1.2" }, null, NoopHostnameVerifier.INSTANCE);
                params.setSSLSocketFactory(context.getSocketFactory());
                params.setHostnameVerifier((s, sslSession) -> true);
                c.setTlsClientParameters(params);
            }catch(Exception e){
                e.printStackTrace();
            }


        }

    public static SSLContext createIgnoreVerifySSL() throws NoSuchAlgorithmException, KeyManagementException {
        SSLContext sc = SSLContext.getInstance("TLS");

        // 实现一个X509TrustManager接口,用于绕过验证,不用修改里面的方法
        X509TrustManager trustManager = new X509TrustManager() {
            @Override
            public void checkClientTrusted(
                    java.security.cert.X509Certificate[] paramArrayOfX509Certificate,
                    String paramString) throws CertificateException {
            }

            @Override
            public void checkServerTrusted(
                    java.security.cert.X509Certificate[] paramArrayOfX509Certificate,
                    String paramString) throws CertificateException {
            }

            @Override
            public java.security.cert.X509Certificate[] getAcceptedIssuers() {
                return null;
            }
        };

        sc.init(null, new TrustManager[]{trustManager}, null);
        return sc;
    }
}

3、调用webservice

java 复制代码
BusFactory bf = CXFBusFactory.newInstance();
Bus bus = bf.createBus();
bus.setExtension(new SoapHTTPConduitConfigurer(), HTTPConduitConfigurer.class);
JaxWsDynamicClientFactory dcf = JaxWsDynamicClientFactory.newInstance(bus);
Client client =null;
try{
   client = dcf.createClient("https://ip:端口/csp/hsb/DHC.Published.PUB0002.BS.PUB0002.CLS?WSDL=1");
}catch(Exception e){
    e.printStackTrace();
    logger.info("webservice连接失败,失败原因:"+e.getMessage());
}
Object[] objects = new Object[0];
try {
  objects = client.invoke("方法名","参数");
}catch(Exception e){
   e.printStackTrace();
   logger.error("调用webservic方法失败:");
}
相关推荐
代码AI弗森4 小时前
无状态的智慧:从 HTTP 到大模型的系统进化论
网络·网络协议·http
酷熊代理4 小时前
安卓手机 IP 切换指南:告别卡顿,轻松换 IP
网络·网络协议·tcp/ip·socks5
不做菜鸟的网工4 小时前
PIM SM +MSDP 组播跨域配置案例
网络协议
大面积秃头6 小时前
Http基础协议和解析
网络·网络协议·http
软件技术员9 小时前
使用ACME自动签发SSL 证书
服务器·网络协议·ssl
我也要当昏君9 小时前
6.4 电子邮件 (答案见原书 P284)
网络协议
せいしゅん青春之我11 小时前
[JavaEE初阶]网络协议-状态码
java·网络协议·http
小蝈蝈啊12 小时前
HTTP相关知识点
网络协议·http·iphone
せいしゅん青春之我14 小时前
[JavaEE初阶]HTTPS-SSL传输过程中的加密
https·java-ee·ssl