关于使用restTemplete调用远程接口出现Pkix path问题的解决方案
加入如下代码即可
import com.xxx.system.service.ISysConfigService;
import com.xxx.system.service.ISysDictService;
import org.apache.http.config.Registry;
import org.apache.http.config.RegistryBuilder;
import org.apache.http.conn.socket.ConnectionSocketFactory;
import org.apache.http.conn.socket.LayeredConnectionSocketFactory;
import org.apache.http.conn.socket.PlainConnectionSocketFactory;
import org.apache.http.conn.ssl.NoopHostnameVerifier;
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
import org.apache.http.conn.ssl.TrustStrategy;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
import org.apache.http.ssl.SSLContexts;
import org.springframework.boot.CommandLineRunner;
import org.springframework.context.annotation.Bean;
import org.springframework.http.client.HttpComponentsClientHttpRequestFactory;
import org.springframework.stereotype.Component;
import org.springframework.web.client.RestTemplate;
import javax.annotation.Resource;
import javax.net.ssl.SSLContext;
/**
* 项目初始化加载
*/
@Component
public class StartUpRunner implements CommandLineRunner {
@Resource
ISysDictService sysDictService;
@Resource
ISysConfigService sysConfigService;
@Override
public void run(String... args) {
System.out.println("============ 服务器启动中....,开始加载数据 ============");
sysDictService.loadAllDictCache();
sysConfigService.loadAllConfig();
}
@Bean
public RestTemplate restTemplate(HttpComponentsClientHttpRequestFactory factory) {
try {
return new RestTemplate(factory);
} catch (Exception e) {
throw new RuntimeException("Unable to initiate RestTemplate for access wechat-proxy.");
}
}
@Bean
public HttpComponentsClientHttpRequestFactory httpComponentsClientHttpRequestFactory() throws Exception {
TrustStrategy acceptingTrustStrategy = (x509Certificates, authType) -> true;
SSLContext sslContext = SSLContexts.custom().loadTrustMaterial(null, acceptingTrustStrategy).build();
LayeredConnectionSocketFactory csf = new SSLConnectionSocketFactory(sslContext, new NoopHostnameVerifier());
Registry<ConnectionSocketFactory> sfr = RegistryBuilder.<ConnectionSocketFactory>create().register("http", PlainConnectionSocketFactory.getSocketFactory()).register("https", csf != null ? csf : SSLConnectionSocketFactory.getSocketFactory()).build();
PoolingHttpClientConnectionManager pollingConnectionManager = new PoolingHttpClientConnectionManager(sfr);
pollingConnectionManager.setMaxTotal(200);
pollingConnectionManager.setDefaultMaxPerRoute(100);
CloseableHttpClient httpClient = HttpClients.custom().setSSLSocketFactory(csf).setConnectionManager(pollingConnectionManager).build();
HttpComponentsClientHttpRequestFactory factory = new HttpComponentsClientHttpRequestFactory();
factory.setHttpClient(httpClient);
factory.setConnectTimeout(60000000);
factory.setReadTimeout(60000000);
factory.setConnectionRequestTimeout(60000000);
return factory;
}
}