有一个需求:要求根据设备mac和终端设备类型来查询设备库存状态。
接口协议是采用webservice协议,信息交互方式为xml格式信息
输入参数存放到XML各个节点下,并转为一个String,作为接口的输入参数。XML的封装格式如下所示:
<?xml version="1.0" encoding="UTF-8"?> <ROOT> <MSG_CONTENT> < DEVICE_MAC></ DEVICE_MAC> < DEVICE_TYPE></ DEVICE_TYPE> </MSG_CONTENT> </ROOT>
输出参数存放到XML各个节点下,并转为一个String,作为接口的输出参数。XML的封装格式如下所示:
<?xml version="1.0" encoding="UTF-8"?> <ROOT> < RESULT_CODE >返回编码</ RESULT_CODE > < RESULT_MSG >失败描述</ RESULT_MSG > <STATE>终端状态</STATE> <IS_EXIST>终端是否存在</IS_EXIST> <OWNER_CITY>终端归属地市</OWNER_CITY> </ROOT>
webservice也就是web服务,是一种跨平台跨语言的服务,类似就是一个第三方的服务,你写好接口让别人来调用,你是提供服务的一方。接口都是用来提供服务的,接口就是一组功能的集合。
在java中写webservice接口,需要在接口类上标注@WebService注解,表明这是一个webservice,@WebParam(name = "DEVICE_MAC")这个注解标注在方法参数上,表示获取的参数,注释用于定制从单个参数至 Web Service 消息部件和 XML 元素的映射。
例如:
@WebService public interface qryIptvStateService { //根据设备mac和设备类型查询库存状态信息 String qryIptvState(@WebParam(name = "DEVICE_MAC") String DEVICE_MAC); }
现在实现这个接口
endpointInterface: 服务接口全路径, 指定做SEI(Service EndPoint Interface)服务端点接口
serviceName:表示对外发布的服务名(也就是接口文档中的方法名),指定 Web Service 的服务名称:wsdl:service。缺省值为 Java 类的简单名称 + Service。
@WebService(endpointInterface = "intf.zznode.device.qryIptvStateService", serviceName = "qryIptvState") public class qryIptvStateServiceImpl extends BaseService implements qryIptvStateService { @Override public String qryIptvState(String xml) { //业务代码 } }
现在开始使用java构建xml文档节点
例如要构建这样结构的xml文档
<ROOT> <MSG_CONTENT> < DEVICE_MAC></ DEVICE_MAC> < DEVICE_TYPE></ DEVICE_TYPE> </MSG_CONTENT> </ROOT>
主要的作用就是便于java对象与xml文件节点元素之间的转换
@XmlRootElement(name = "ROOT")将这个注解标注在java类上,表示这个是xml文档的根元素,名字为ROOT。
@XmlRootElement(name = "ROOT") public class ROOTStoreInfo { //root下面的msg_content元素 private StoreMsgContent MSG_CONTENT; //setter/getter方法 } public class StoreMsgContent { private String DEVICE_MAC; private String DEVICE_TYPE; //setter/getter方法 } 最终构建出来的xml文档为 <ROOT> <MSG_CONTENT> < DEVICE_MAC></ DEVICE_MAC> < DEVICE_TYPE></ DEVICE_TYPE> </MSG_CONTENT> </ROOT> //最后需要将传入的xml格式的字符串映射解析为java类 public static <T> T xml2Object(String xmlStr, Class<T> c) { try { // JAXB(即Java Architecturefor XML Binding)是一个业界的标准, //即是一项可以根据XML Schema产生Java类的技术。 //该过程中,JAXB也提供了将XML实例文档反向生成Java对象树的方法, //并能将Java对象树的内容重新写到XML实例文档。 JAXBContext context = JAXBContext.newInstance(c); Unmarshaller unmarshaller = context.createUnmarshaller(); T t = (T) unmarshaller.unmarshal(new StringReader(xmlStr)); return t; } catch (JAXBException e) { e.printStackTrace(); return null; } }
现在能够实现用java类构建xml格式的文档节点信息,并且能将传入的字符形式的xml格式数据映射为标注了@XmlRootElement的类。
现在需要将操作结果返回。
//用于响应返回的xml文档信息 //@XmlType 注解 propOrder的值是一个字符串数组,用来设置xml文档节点的顺序 @XmlRootElement(name = "ROOT") @XmlType(propOrder = {"RESULT_CODE", "RESULT_MSG", "STATE", "IS_EXIST", "OWNER_CITY","OTT_STB_ID"}) public class ROOTStoreInfoRespone { private String RESULT_CODE;//返回编码:1成功,0失败 private String RESULT_MSG;//失败描述,RESULT_CODE为0必填 private String STATE;//终端设备状态,RESULT_CODE为1必填 private String IS_EXIST;//终端设备是否存在:1存在,0不存在 private String OWNER_CITY;//终端归属地市,IS_EXIST为1时必填 private String OTT_STB_ID;//OTT序列号sn //setter/getter方法 } //用于将java类转换为xml格式 public static String getXml(ROOTStoreInfoRespone root) { StringWriter wr = new StringWriter(); try { //JAXBContext将java类与xml文档相互转换 JAXBContext context = JAXBContext.newInstance(ROOTStoreInfoRespone.class); //使用Marshaller生成xml文件 Marshaller mar = context.createMarshaller(); //格式化xml格式 mar.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true); //去掉生成xml的默认报文头 // mar.setProperty(Marshaller.JAXB_FRAGMENT, true); mar.marshal(root, wr); return wr.toString().replace("standalone=\"yes\"", ""); } catch (JAXBException e) { // TODO Auto-generated catch block e.printStackTrace(); } return null; } //调用 getXml(rootStoreInfoRespone)
总结:
java写webservice部分
@WebService注解用于标注一个接口类,表示这是一个webservice。
@WebParam(name = "DEVICE_MAC")注解用于标注参数,这个参数和传入的xml节点元素名相同,值为这个节点的值。
@WebService(endpointInterface = "intf.zznode.device.qryIptvStateService", serviceName = "qryIptvState") 用于标注在实现了webservice接口的实现类上。
endpointInterface 表示接口类的全路径,serviceName 表示对外提供的webservice方法名称。
java构建和解析xml部分
@XmlRootElement(name = "ROOT")将这个注解标注在java类上,表示这个是xml文档的根元素,名字为ROOT。这个类里面的属性即为xml中的节点元素。
@XmlType(propOrder = {"RESULT_CODE", "RESULT_MSG", "STATE", "IS_EXIST", "OWNER_CITY","OTT_STB_ID"})表示是xml类型。
propOrder 是一个字符数组,表示的是xml中节点元素的先后顺序。
xml格式的字符串映射为java类
将java类解析为xml文档格式。
主要是这次开发任务做了一个这样的需求,特此记录一下,对于webservice还不是很熟悉,还需要加强学习。