java使用cxf调用https方式的webservice

推荐尝试hutool工具调用:

webservice服务利用hutool工具调用wsdl超简单_XYLANCC的博客-CSDN博客_hutool 调用wsdl

以下内容转载之后亲自测试过,又整理添加了linux服务器下的配置过程:
转载地址
第一步:导入cxf必须的jar包,当前使用的cxf的版本为3.0.5

		<!-- 5.CXF -->
		<dependency>
			<groupId>org.apache.cxf</groupId>
			<artifactId>cxf-rt-frontend-jaxws</artifactId>
			<version>3.0.5</version>
		</dependency>
		<dependency>
			<groupId>org.apache.cxf</groupId>
			<artifactId>cxf-rt-transports-http</artifactId>
			<version>3.0.5</version>
		</dependency>

		<dependency>
			<groupId>org.apache.cxf</groupId>
			<artifactId>cxf-rt-ws-security</artifactId>
			<version>3.0.5</version>
		</dependency>
		<dependency>
			<groupId>org.apache.ws.security</groupId>
			<artifactId>wss4j</artifactId>
			<version>1.5.2</version>
		</dependency>

第二步:导出网站证书
https区别于http即https需要证书,接下来我们导出证书。
以下操作方式为谷歌内核浏览器操作方式,各大浏览器均支持导出证书,具体不了解的自行百度。
浏览器输入接口地址https://xxxxx/abc/ws/soap/sendHis?wsdl
wsdl
在这里插入图片描述
点击sercurty选择 view certificate
在这里插入图片描述
选择详细信息。点击保存证书
在这里插入图片描述
格式选择二进制,接下一步导出证书,到此我们得到一个.cer文件-这个就是客户端的证书(生成的是ws服务端的证书,需要将证书导入到ws-client端)
接下来要区分在windows系统和linux服务的证书导入情况:
windows服务器:
第三步:向jdk中导入信任安全证书,生成key
确保本地安装了jdk,我们需要使用jdk中的keytool工具。
在cmd命令行,输入

keytool -import -alias fosafer -file d:\\fosafer.cer -keystore d:\\fosafer.keystore

(此命令导入安全证书,同时需要添加一个密码,在后续代码使用中用)生成key,生成过程中会需要你输入key的密码,密码记录下来这个到后面会有用。
第四步:调用

		//设置ws需要的https证书cacerts
		System.setProperty("javax.net.ssl.trustStore","D:\\fosafer.keystore"); //key路径
		System.setProperty("javax.net.ssl.trustStorePassword","your pwd");//密码
		System.setProperty("java.protocol.handler.pkgs","com.sun.net.ssl.internal.www.protocol"); 
		java.security.Security.addProvider(new com.sun.net.ssl.internal.ssl.Provider());
		
		//创建ws服务
		JaxWsProxyFactoryBean jaxWsProxyFactoryBean = new JaxWsProxyFactoryBean();

		jaxWsProxyFactoryBean.setAddress(url);
		T create = jaxWsProxyFactoryBean.create(t);

		return create;

在我们实际调用之前(创建连接之前),添加了4行代码,至此,使用Java调用Https方式的接口调用成功。
linux服务器:(只需要改一下windows操作的第三部即可)
第三步:向jre中导入信任安全证书,生成key
确保本地安装了jdk,我们需要使用jdk中的keytool工具。

keytool -import -alias fosafer -file /data/guoxxx/tomcat-wsclient/keystore/fosafer.cer -keystore "/usr/local/jdk1.7.0_80/jre/lib/security/cacerts"

注意:密码输入 changeit

(此命令导入安全证书,同时需要添加一个密码,在后续代码使用中用)生成key,生成过程中会需要你输入key的密码,密码记录下来这个到后面会有用。
接下来执行第四部调用。

在此附加一下导入证书的命令:

keytool -import -alias taobao -file taobao.cer -keystore "%JAVA_HOME%/jre/lib/security/cacerts"  -storepass changeit-trustcacerts

和证书相关的命令:

//查看cacerts中的证书列表:
 keytool -list -keystore "%JAVA_HOME%/jre/lib/security/cacerts"  -storepass changeit
//删除cacerts中指定名称的证书:
 keytool -delete -alias taobao -keystore "%JAVA_HOME%/jre/lib/security/cacerts"  -storepass changeit
//导入指定证书到cacerts:
 keytool -import -alias taobao -file taobao.cer -keystore "%JAVA_HOME%/jre/lib/security/cacerts"  -storepass changeit-trustcacerts

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值