1.首先交代一下背景:
入职后项目组交给我的第一个任务便是做一个酒店直连对接,流程说白了就是发xml报文去携程的系统,携程返回xml里面包含了酒店相关信息,流程听着很简单,但是涉及到跟携程对接、跟公司内部系统对接,作为一个中间层,项目进度很难自己把控,再加上酒店这块业务也挺复杂的,看相关文档就花了两天梳理,所以也很是头疼。
下面说一下技术遇到的难点:事前拿postman往携程系统请求一个酒店的静态信息,结果返回了4M多的xml数据,postman直接崩掉;所以用什么方式解析XML报文要仔细考。Java经常用dom4j解析xml,但是dom4j会将整个XML文档加载到内存中,返回的报文这么大将消耗大量内存;SAX是基于流解析xml的一种技术,但是SAX是读取一段解析一段xml的,速度自然而然非常慢。
上面两种常见的xml解析技术很快被我否定,接着我很快地想到jaxb,jdk6之后它就成为了官网的工具,而且采用的是对象属性与xml的映射;问了一下携程对接人员,没有.xsd文件,可能手动生成那么多对象会比较累,当时觉得麻烦可能仅限于此。
2.实际开工遇到的问题
放上XML就很明显易见了
<Request>
<Header AllianceID="12345" SID="12345" TimeStamp="1509679923" RequestType="OTA" Signature="12345"/>
<HotelRequest>
<RequestBody xmlns:ns="http://www.lyyco.cc/OTA/2003/05" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<OTA_HotelDescriptiveInfoRQ Version="1.0" xsi:schemaLocation="http://www.lyyco.cc/OTA/2003/05 OTA.xsd" xmlns="http://www.lyyco.cc/OTA/2003/05" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<HotelDescriptiveInfos>
<HotelDescriptiveInfo HotelCode="625">
<HotelInfo SendData="true"/>
<FacilityInfo SendGuestRooms="true"/>
<AreaInfo SendAttractions="true"SendRecreations="true"/>
<ContactInfo SendData="true"/>
<MultimediaObjects SendData="true"/>
</HotelDescriptiveInfo>
</HotelDescriptiveInfos>
</OTA_HotelDescriptiveInfoRQ>