1、新建RefundResult.java文件:
/** * */ package com.saicfc.pmpf.resume.ccb.utils; import java.util.List; import com.thoughtworks.xstream.annotations.XStreamAlias; import com.thoughtworks.xstream.annotations.XStreamImplicit; /** * 解析银行返回数据 * @author lizhiyong * @version $Id: QueryOrders2.java,v 0.1 2014年7月24日 下午3:30:47 Exp $ */ @XStreamAlias("TX") public class RefundResult { @XStreamAlias("REQUEST_SN") public String requestSn; @XStreamAlias("CUST_ID") public String custId; @XStreamAlias("TX_CODE") public String txcode; @XStreamAlias("RETURN_CODE") public String returnCode; @XStreamAlias("RETURN_MSG") public String returnMsg; @XStreamAlias("LANGUAGE") public String language; @XStreamAlias("TX_INFO") public TxInfo2 txInfo2; public static class TxInfo2{ @XStreamAlias("CUR_PAGE") public String curPage; @XStreamAlias("TPAGE") public String tPage; @XStreamImplicit(itemFieldName="LIST") public List<QueryOrder> queryOrders; @XStreamAlias("NOTICE") public String notice; public String getCurPage() { return curPage; } public String getNotice() { return notice; } public String gettPage() { return tPage; } public List<QueryOrder> getQueryOrders() { return queryOrders; } } public static class QueryOrder { @XStreamAlias("TRAN_DATE") public String tranDate; @XStreamAlias("REFUND_DATE") public String refundDate; @XStreamAlias("ORDER_NUMBER") public String orderNumber; @XStreamAlias("REFUND_ACCOUNT") public String refundAccount; @XStreamAlias("PAY_AMOUNT") public String payAmount; @XStreamAlias("REFUNDEMENT_AMOUNT") public String refundementAmount; @XStreamAlias("POS_CODE") public String posCode; @XStreamAlias("USERID") public String userId; @XStreamAlias("STATUS") public String status; public String getTranDate() { return tranDate; } public String getRefundDate() { return refundDate; } public String getOrderNumber() { return orderNumber; } public String getRefundAccount() { return refundAccount; } public String getPayAmount() { return payAmount; } public String getRefundementAmount() { return refundementAmount; } public String getPosCode() { return posCode; } public String getUserId() { return userId; } public String getStatus() { return status; } } public String getRequestSn() { return requestSn; } public String getCustId() { return custId; } public String getTxcode() { return txcode; } public String getReturnCode() { return returnCode; } public String getReturnMsg() { return returnMsg; } public String getLanguage() { return language; } public TxInfo2 getTxInfo2() { return txInfo2; } }
2、解析XML文件:
XStream xStream = new XStream(new DomDriver()); xStream.processAnnotations(RefundResult.class); RefundResult query = (RefundResult) xStream.fromXML(revResult); Map<String,Object> orderMap = new HashMap<String,Object>(); orderMap.put("returnCode",query.getReturnCode()); orderMap.put("returnMsg",query.getReturnMsg()); //交易成功 if ("000000".equals(orderMap.get("returnCode"))) { orderMap.put("requestSn",query.getRequestSn()); orderMap.put("custId",query.getCustId()); orderMap.put("txcode",query.getTxcode()); orderMap.put("language",query.getLanguage()); TxInfo2 txInfo2 = query.getTxInfo2(); orderMap.put("curPage",txInfo2.getCurPage()); orderMap.put("tPage",txInfo2.gettPage()); List<QueryOrder> queryList = txInfo2.getQueryOrders(); List queryOrderList = new ArrayList(); Map<String,Object> queryMap = null; for (Iterator iterator = queryList.iterator(); iterator.hasNext();) { QueryOrder queryOrder = (QueryOrder) iterator.next(); queryMap = new HashMap<String,Object>(); queryMap.put("tranDate",queryOrder.getTranDate()); queryMap.put("refundDate",queryOrder.getRefundDate()); queryMap.put("orderNumber",queryOrder.getOrderNumber()); queryMap.put("refundAccount",queryOrder.getRefundAccount()); queryMap.put("payAmount",queryOrder.getPayAmount()); queryMap.put("refundementAmount",queryOrder.getRefundementAmount()); queryMap.put("posCode",queryOrder.getPosCode()); queryMap.put("userId",queryOrder.getUserId()); queryMap.put("status",queryOrder.getStatus()); //把每一个订单信息都存放在queryOrderList中 queryOrderList.add(queryMap); } //把所有订单信息集合queryOrderList存放到orderMap中 orderMap.put("queryOrderList",queryOrderList); logger.info("解析银行退款查询返回数据结束:" + orderMap); return orderMap; }