XML--两个系统采用servlet发送及解析XML

前端之家收集整理的这篇文章主要介绍了XML--两个系统采用servlet发送及解析XML前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

例子:

代码第16行打开一个地址的连接,返回HttpURLConnection对象。

第22行将要传送的XML内容写入HttpURLConnection的 OutputStream流中。(注意 这里需要传入byte字节数组)

然后23行调用.getInputStream()此时才会跳转到服务器端servlet,如果不调用.getInputStream()是不会跳转过去的。

客户端:

package adopen;

import java.io.InputStream;
import java.io.OutputStreamWriter;
import java.net.HttpURLConnection;
import java.net.URL;

import com.haier.util.AesUtil;
import com.haier.util.StreamTool;

public class URLTest {

	public static String testServletUrl(String path,String xml)
			throws Exception {
		URL url = new URL(path);
		HttpURLConnection conn = (HttpURLConnection) url.openConnection();
		conn.setRequestMethod("POST");// 提交模式
		conn.setConnectTimeout(10000);// 连接超时 单位毫秒
		conn.setReadTimeout(5000);// 读取超时 单位毫秒
		conn.setDoOutput(true);// 是否输入参数
		// 通过conn.getOutputStream().write 将XML信息写入,在另一端系统,get出来再解析
		conn.getOutputStream().write(xml.getBytes("UTF-8"));
		InputStream inStream = conn.getInputStream();
		inStream.close();
		return xml;
	}

	public static String getCampaginXmlInfo() {
		StringBuilder sb = new StringBuilder();
		sb.append("<?xml version=\"1.0\" encoding=\"UTF-8\"?>");
		sb.append("<haier_ad>");
		sb.append("    <campName>Campaign</campName>");
		sb.append("    <agent_ID>Agent001</agent_ID>");
		sb.append("    <client_ID>Client001</client_ID>");
		sb.append("    <sDate>2013-07-10 00:00:00</sDate>");
		sb.append("    <eDate>2013-10-10 00:00:00</eDate>");
		sb.append("    <coverID>cover002</coverID>");
		sb.append("</haier_ad>");
		return sb.toString();
	}

	public static void main(String[] args) {
		try {// testPostServlet
			String result = null;
			result = URLTest.testServletUrl(
					"http://localhost:8080/haierAdOpenApi/domTestServlet",getCampaginXmlInfo());
			System.out.println("result:" + result);
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}


客户端发送过来的xml文件采用DOM进行解析。详见xml--通过DOM解析XML

注意:我这里用的servlet3.0,采用注解的来替换web.xml中的配置

@WebServlet(urlPatterns = { "/domTestServlet" },asyncSupported = true),如果您不是servlet3.0版本,还需要在web.xml中配置servlet的跳转信息。

服务端:

package com.haier.web;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

import org.w3c.dom.DOMException;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

/**
 * 使用递归解析给定的任意一个xml文档并且将其内容输出到命令行上
 * 
 * @author zhanglong
 * 
 */
@WebServlet(urlPatterns = { "/domTestServlet" },asyncSupported = true)
public class DomTestServlet extends BaseServlet {

	protected void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException {
		doPost(request,response);
	}

	protected void doPost(HttpServletRequest request,IOException {
		try {// step 1: 获得dom解析器工厂(工作的作用是用于创建具体的解析器)
			DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();

			// System.out.println("class name: " + dbf.getClass().getName());

			// step 2:获得具体的dom解析器
			DocumentBuilder db = dbf.newDocumentBuilder();

			// System.out.println("class name: " + db.getClass().getName());

			// step3: 解析一个xml文档,获得Document对象(根结点)
			Document document = db.parse(request.getInputStream());

			NodeList list = document.getElementsByTagName("haier_ad");

			for (int i = 0; i < list.getLength(); i++) {
				Element element = (Element) list.item(i);

				String content = element.getElementsByTagName("campName")
						.item(0).getFirstChild().getNodeValue();

				System.out.println("campName:" + content);

				content = element.getElementsByTagName("agent_ID").item(0)
						.getFirstChild().getNodeValue();

				System.out.println("agent_ID:" + content);

				content = element.getElementsByTagName("client_ID").item(0)
						.getFirstChild().getNodeValue();

				System.out.println("client_ID:" + content);

				content = element.getElementsByTagName("coverID").item(0)
						.getFirstChild().getNodeValue();

				System.out.println("coverID:" + content);
			}
		} catch (DOMException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (ParserConfigurationException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (SAXException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

	}
}

猜你在找的XML相关文章