使用自定义签名的https的ssl安全问题解决和metro的webservice调用

最近一直在忙新的项目,每天加班到8点多,都没来写博客了。新的项目遇到了很多问题,现在趁着突然停电来记录下调用https的问题吧。

我们服务主要是,我们调用数据源数据,并且再提供接口供外部数据调用。

我们提供给客户的接口采用https+post的方式,调用数据源的数据是以https的webservice。由于我们的签名是自签的,所以客户调用我们的接口要绕过安全认证,我们都要在sdk里面提供给他。

 private static volatile RestfulRemoteHttpsHelper instance; private ConnectionConfig connConfig; private SocketConfig socketConfig; private ConnectionSocketFactory plainSF; private KeyStore trustStore; private SSLContext sslContext; private LayeredConnectionSocketFactory sslSF; private Registry<ConnectionSocketFactory> registry; private PoolingHttpClientConnectionManager connManager; private volatile HttpClient client; private volatile BasicCookieStore cookieStore; public static String defaultEncoding= "utf-8"; private HttpsHelper(){ //设置连接参数 connConfig = ConnectionConfig.custom().setCharset(Charset.forName(defaultEncoding)).build(); socketConfig = SocketConfig.custom().setSoTimeout(100000).build(); RegistryBuilder<ConnectionSocketFactory> registryBuilder = RegistryBuilder.<ConnectionSocketFactory>create(); plainSF = new PlainConnectionSocketFactory(); registryBuilder.register("http", plainSF); //指定信任密钥存储对象和连接套接字工厂 try { trustStore = KeyStore.getInstance(KeyStore.getDefaultType()); sslContext = SSLContexts.custom().useTLS().loadTrustMaterial(trustStore, new AnyTrustStrategy()).build(); sslSF = new SSLConnectionSocketFactory(sslContext, SSLConnectionSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER); registryBuilder.register("https", sslSF); } catch (KeyStoreException e) { throw new RuntimeException(e); } catch (KeyManagementException e) { throw new RuntimeException(e); } catch (NoSuchAlgorithmException e) { throw new RuntimeException(e); } registry = registryBuilder.build(); //设置连接管理器 connManager = new PoolingHttpClientConnectionManager(registry); connManager.setDefaultConnectionConfig(connConfig); connManager.setDefaultSocketConfig(socketConfig); //指定cookie存储对象 cookieStore = new BasicCookieStore(); //构建客户端 client= HttpClientBuilder.create().setDefaultCookieStore(cookieStore).setConnectionManager(connManager).build(); }

上面代码是用httpClient4.3来绕过https的请求调用。

通过webservice调用数据源的数据由于他们有专门的信任证书签发,所以可以把他们的签名证书加入信任库。关于怎么根据keystore生成truststore可以使用jdk的keytool工具,在jdk安装目录下的bin文件夹里面。

keystore生成truststore:

通过cmd进入jdk的的bin目录下,输入keytool -export -alias 别名 -keystore client.keystore -rfc -file client.cer,会提示输入密码,别名和密码需要签名方提供。生成.cer文件,文件在jdk安装目录下。再输入keytool import -alias 别名 -file client.cer -keystore client.truststore生成truststore,记住输入的密码。

把keystore和truststore加入到信任库里。

 System.setProperty("javax.net.ssl.keyStore", keyPath); System.setProperty("javax.net.ssl.keyStorePassword", "key-password"); System.setProperty("javax.net.ssl.trustStore", trustPath); System.setProperty("javax.net.ssl.trustStorePassword", "trust-password");

如果用axis做webservice的调用framework的话就可以使用了,这次我们用的是metro。

关于metro可以参考官网。https://metro.java.net

把metro加入到gradle依赖 –> compile ‘org.glassfish.metro:webservices-rt:2.3’。

 生成client代码调用?可以借助wsimport这个工具,注意在生成代码时,加上-keep 属性,不然只会生成class文件,而木有Java文件。

生成的文件目录:

使用自定义签名的https的ssl安全问题解决和metro的webservice调用

把生成的client代码导入项目中,如果不出意外的话会报subject-alternative-names-present这个异常,如果是jdk8的话,用lambda表达式

HttpsURLConnection.setDefaultHostnameVerifier((hostname, session) -> hostname.equals("主机ip"));

如果是低版本,这样

HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier() { public boolean verify(String hostname, SSLSession session) { // ip address of the service URL(like.23.28.244.244) if (hostname.equals("主机ip")) return true; return false; } });

现在可以测试了,测试代码

 @Test public void testMetro() { StopWatch clock = new StopWatch("metro clock"); QueryService queryService = queryServiceService.getQueryService(); for (int i = 0; i < 20; i++) { clock.start("start the " + i + "connection"); String result = queryService.getMethod("xxx", "xxx", "xxx", "xxx", "xxx", "xxx", null, "xxx", null, null, null, null); System.out.println("the first number result :" + result); clock.stop(); } }

为了测试性能,用到了StopWatch 这个类做时间计时器,关于StopWatch的使用搜索一大把。测试结果的效果不怎么样,因为这样是每次调用都握手,而握手的时间太长了。为了优化可以让连接keep-alive,详情参考官网

https://metro.java.net/guide/ch05.html#http-persistent-connections-keep-alive

在Java代码里实现,后面的value值可以根据实际情况来改变。

System.setProperty("http.keepAlive", "true"); System.setProperty("http.maxConnections", "250"); System.setProperty("keep-alive.max-connections", "1000");

测试结果

使用自定义签名的https的ssl安全问题解决和metro的webservice调用

经过添加keep-alive,明显调用效果好了很多(这是我本机测试的,用nginx做了代理,实际部署到服务器还没测试,效果应该会更好)。

这里的webservice的性能还能再次优化,只是现在还没做。等优化好了再来记录!

语文水平不怎么样,东说一句西说一句,有点乱。关于这个项目的问题还有好多没能记录,有时间再来整理。

原文链接:https://www.cnblogs.com/qldhlbs/p/5626511.html

原创文章,作者:优速盾-小U,如若转载,请注明出处:https://www.cdnb.net/bbs/archives/18418

(0)
优速盾-小U的头像优速盾-小U
上一篇 2023年8月26日 18:56
下一篇 2023年8月26日 21:22

相关推荐

  • TypeC的特性

    1、电能传输功能差异。 USB Typc-C的特点在于,所有支持TYPE-C接口标准的设备都可以通过接口规范中的CC引脚的电平来向连接的另一方宣称自己占用VBUS的意愿,较强意愿的…

    网站百科 2024年1月20日
    00603
  • web安全之路

    为工作室萌新所作。记得以前刚学习安全时,醉心于技术,但却是一直学习不得法,当时我们那批人不懂计算机原理,不懂编程,只是粗浅理解一些网络,加之安全也很难内容庞杂,不知到该学哪些,学完…

    网站百科 2023年7月11日
    00824
  • 网站TDK三大标签SEO优化

    title、description、keyword   1.title 网站标题 title 具有不可替代性,是我们内页的第一个重要标签,是搜索引擎了解网页的入口和对网页…

    网站百科 2024年2月13日
    00535
  • RackNerd 圣何塞 VPS 测评

    发布于 2023-07-06 on https://chenhaotian.top/vps/racknerd-ca/ RackNerd 圣何塞 VPS 测评 官网链接&#xff1a…

    网站百科 2024年8月21日
    00648
  • 怎么选择服务器

    建网站过程中一定会遇到的一个问题是:服务器如何选择。服务器的选择大概分为以下几种情况: 一、个人网站或者入门级网站,这类网站由于网站内容和…

    网站百科 2025年6月18日
    00224
  • WEB安全

    1、DOS 拒绝服务攻击 ddos的攻击方式有很多种,最基本的DoS攻击就是利用合理的服务请求来占用过多的服务资源,从而使合法用户无法得到服务的响应。 ddos攻击利用的就是合理的…

    2023年9月10日
    00781
  • 初尝CDN:什么是分布式服务节点?

    什么是cdn?笔者初见时也是摸不着头脑,查阅了大量的资料才明白什么是CDN,笔者为您揭秘什么是CDN? CDN的全称是Content Delivery Netw…

    网站百科 2025年6月18日
    00288
  • DNS预解析 dns-prefetch

    1、DNS 是什么? Domain Name System,域名系统,作为域名和IP地址相互映射的一个分布式数据库。 DNS大家都懂,那么浏览器访问域名的时候,是需要去解析一次DN…

    网站百科 2023年11月27日
    00586
  • DDOS攻击防御

    ddos攻击流量大、攻击次数频繁、发起攻击成本低,本质上是攻击发起者通过控制大量的僵尸网络对站点进行分布式攻击。 DNS Query Flood就是攻击者操纵大量傀儡机器,对目标发…

    网站百科 2023年9月19日
    00654
  • react 或者 vue,如何做 SEO 优化?

    当涉及前端框架时,很多人都认为依赖 Node 的 SSR 是做 SEO 的唯一解决方案。但如果是运行在共享虚拟主机中、或是没有 root 权限等情况下,…

    网站百科 2023年8月23日
    00660

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

优速盾注册领取大礼包www.cdnb.net
/sitemap.xml