开这个坑源于我现在做的一个项目用到了SOAP。关于SOAP的知识我就不做详细介绍了。我也没有开发过SOAP服务端, 只是要用到客户端。
作为一个意识流选手,我大概说一下我工作过程中对SOAP的印象。
1、 SOAP的出现是为了解决跨平台的问题。比如java调用一个c#或者php写的服务
2、 数据传输是基于xml的。上一点说到是为了解决跨平台的问题,但是很蛋疼的是,并没有很严格的标准去规定xml的数据格式。导致这个标准并不是唯一的。这就非常操蛋了。逆向生成的代码经常没用,甚至使用逆向工具的时候偶尔还会报错(我这个项目还有一点别的原因)。
3、我用Eclipse根wsdl生成的客户端访问SOAP服务特别慢。而且并不是服务端的问题。我用 TCP Monitor 截获了请求,数据返回特别快20ms左右,但是客户端把返回数据处理成相应的bean特别慢。导致整个调用花费了1分钟
4、有很多手写客户端的办法。但是我觉得都太麻烦了。而且像Axis2我不知道为什么从Maven下载依赖下不下来,javax有一个对soap的支持,但是在一些java版本移来移去,java8是有的,java9就移除了。
5、于是我开始自己琢磨在现有的基础上写一个通用的方法去构造请求的内容。一开始想用Axis2,上面说了,下载不下来。。然后就用javax的soap。发现很不灵活,凑不出我项目里要的格式。然后还想过直接用StringBuilder,但是很不好用。最后选择了Dorm4j + javax自带的soap
说到我工作用到的SOAP server。那还是大佬十年前写的,真的很佩服,他们没有什么工具。完全用C根据SOAP协议写了一个SOAP Server。真的是强, 里面的源码是完完全全地对字符串的解析,膜拜大佬。但是估计是只对C#调用做了很多测试。C#的客户端调用特别快。我现在要用java调用,逆向生成的代码把数据传过去有一部分是解析不到的。我现在就是想办法把java调用时的数据做成跟C#调用的数据写成一样的。