用DOM建立XML文件

用DOM建立XML文件,第1张

response.setContentType("text/xmlcharset=UTF-8")

request.setCharacterEncoding("UTF-8")

response.setHeader("Cache-Control","no-cache")

PrintWriter

out

=

response.getWriter()

out.println("<content>")

out.println("<cessvalue>"

+cessvalue

+

"</cessvalue>")

out.println("<basicsum>"

+

basicsum

+

"</basicsum>")

out.println("<koubasic>"

+

koubasic

+

"</koubasic>")

out.println("<yifa>"

+yifa+

"</yifa>")

out.println("<cesspay>"

+cesspay+

"</cesspay>")

out.println("</content>")

写在servlet

里面,直接把它输出来就可以了

一、在Android应用中的XML文件来源

1、本地xml文件

本地XML文件可以放在应用根目录assets文件夹、res/xml、res/raw、SDcard卡、应用的data目录等;

除res/xml可直接通过getXml(int id)获取XML文档,返回一个解析器对象(XmlResourceParer:XmlResourceParer是XmlPullParser的子类),其它位置情况都可以获取XML文档,返回一个Inputstream对象,进行读取数据,获取方法分别如下:

a.在res/xml目录下(推荐使用):

[java] view plaincopy

XmlResourceParser xmlParser = this.getResources().getXml(R.xml.XXX)

b.在res/xml、res/raw目录下:

[java] view plaincopy

InputStream inputStream = this.getResources().openRawResource(R.xml.XXX)

c.在assets文件夹下(本人测试发现通过此方法获取的XML文档不能带有首行:<?xml version="1.0" encoding="utf-8"?>,否则解析报错,具体原因未查明,知道原因请回复交流):

[java] view plaincopy

InputStream inputStream = getResources().getAssets().open(fileName)

d.在应用指定目录下(SDcard,应用data目录等):

[java] view plaincopy

// path路径根据实际项目修改,此次获取SDcard根目录

String path = Environment.getExternalStorageDirectory().toString()

File xmlFlie = new File(path+fileName)

InputStream inputStream = new FileInputStream(xmlFlie)

2、通过url得到的xml文件

很多时候需要解析xml文件都用于客户端与服务器之间的数据交互,比如解析google天气预报信息,或自己项目内定的一些XML数据结构,其中通过URL,使用DefaultHTTPClient get请求获取XML文件方法如下:

[java] view plaincopy

/**

* 读取url的xml资源 转成String

* @param url

* @return 返回 读取url的xml字符串

*/

public String getStringByUrl(String url) {

String outputString = ""

// DefaultHttpClient

DefaultHttpClient httpclient = new DefaultHttpClient()

// HttpGet

HttpGet httpget = new HttpGet(url)

// ResponseHandler

ResponseHandler<String>responseHandler = new BasicResponseHandler()

try {

outputString = httpclient.execute(httpget, responseHandler)

outputString = new String(outputString.getBytes("ISO-8859-1"), "utf-8") // 解决中文乱码

Log.i("HttpClientConnector", "连接成功")

} catch (Exception e) {

Log.i("HttpClientConnector", "连接失败")

e.printStackTrace()

}

httpclient.getConnectionManager().shutdown()

return outputString

}

二、XML文件的解析方式

能够运用在Android系统上解析XML文件的常用有三种方式:DOM、SAX和PULL,其中DOM解析XML是先把XML文件读进内存中,再通过接口获取数据,该方法使用相对小的XML文件,移动设备往往受硬件性能影响,如果XML文件比较大使用DOM解析往往效率跟不上;SAX和PULL都是采用事件驱动方式来进行解析,在Android中的事件机制是基于回调函数。

本例旨在考虑简单方便性,综合考虑选择了PULL解析,PULL解析器是一个开源项目,Android平台已经内置了PULL解析器,同时Android系统本身也是使用PULL解析器来解析各种XML文档。

1、事件回调类型

PULL解析XML文件时,回调XmlResourceParser内定义表示文档开头结束和节点开头结束的数值(事件回调类型),表示如下:

a.读取到XML文档开头(声明)返回:XmlPullParser.START_DOCUMENT(0)

b.读取到XML文档结束返回:XmlPullParser.END_DOCUMENT (1)

c.读取到XML节点开始返回:XmlPullParser.START_TAG (2)

d.读取到XML节点结束返回:XmlPullParser.END_TAG (3)

e.读取到XML文本返回:XmlPullParser.TEXT (4)

2、XmlPullParser有几个主要方法(更多查阅Android APIs):

a.XmlPullParser.getEventType() : Returns the type of the current event (START_TAG, END_TAG, TEXT, etc.) 【获取当前事件回调类型】

b.XmlPullParser.getName():For START_TAG or END_TAG events, the (local) name of the current element is returned when namespaces are enabled.【获取当前节点名字】

c.XmlPullParser.getAttributeValue(int index):Returns the given attributes value.【根据id获取节点属性值】

d.XmlPullParser.getAttributeValue(String namespace, String name):Returns the attributes value identified by namespace URI and namespace localName.【根据name获取节点属性值】

e.XmlPullParser.netxText():If current event is START_TAG then if next element is TEXT then element content is returned or if next event is END_TAG then empty string is returned, otherwise exception is thrown.【回调节点START_TAG时,通过此方法获取节点内容】

3、实际编码中如何使用

在实际编码中,主要根据事件回调类型,结合被解析的XML结构进行解析提取数据,PULL解析XML文件的主要模式如下,更具体使用看本文提供的例子:

[java] view plaincopy

try {

//开始解析事件

int eventType = parser.getEventType()

//处理事件,不碰到文档结束就一直处理

while (eventType != XmlPullParser.END_DOCUMENT) {

//因为定义了一堆静态常量,所以这里可以用switch

switch (eventType) {

case XmlPullParser.START_DOCUMENT:

// 不做任何 *** 作或初开始化数据

break

case XmlPullParser.START_TAG:

// 解析XML节点数据

// 获取当前标签名字

String tagName = parser.getName()

if(tagName.equals("XXXTAGXXX")){

// 通过getAttributeValue 和 netxText解析节点的属性值和节点值

}

break

case XmlPullParser.END_TAG:

// 单节点完成,可往集合里边添加新的数据

break

case XmlPullParser.END_DOCUMENT:

break

}

// 别忘了用next方法处理下一个事件,不然就会死循环

eventType = parser.next()

}

} catch (XmlPullParserException e) {

e.printStackTrace()

}catch (IOException e) {

e.printStackTrace()

}

一个XML文档,可以先构造一个DOM,然后将DOM转化为xml序列,输出或者生成文件。package test

import java.io.ByteArrayOutputStream

import java.io.File

import java.io.FileOutputStream

import javax.xml.parsers.DocumentBuilder

import javax.xml.parsers.DocumentBuilderFactory

import javax.xml.transform.Transformer

import javax.xml.transform.TransformerFactory

import javax.xml.transform.dom.DOMSource

import javax.xml.transform.stream.StreamResult

import org.w3c.dom.Document

import org.w3c.dom.Element

public class Test {

public static void generate(){

try {

DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance()

DocumentBuilder builder = factory.newDocumentBuilder()

Document document = builder.newDocument()

document.setXmlVersion("1.0")

document.setXmlStandalone(true)

Element root = document.createElement_x("MobileNet") //创建根节点

document.appendChild(root) //将根节点添加到Document对象中

Element pageElement = document.createElement_x("page")//设置第一个page元素到

pageElement.setAttribute("name", "list.jsp")//设置page节点的name属性

Element methodElement = document.createElement_x("method") //设置method节点

methodElement.setTextContent("get") //给method设置值

pageElement.appendChild(methodElement)//添加method节点到page节点内

Element displayElement = document.createElement_x("display") //设置method节点

displayElement.setTextContent("list撒旦发放")//给display设置值

pageElement.appendChild(displayElement) //添加display节点到page节点内

Element request_paramElement = document.createElement_x("request_param")

request_paramElement.setTextContent("request_param1|request_param2")

pageElement.appendChild(request_paramElement)

root.appendChild(pageElement)

pageElement = document.createElement_x("page") //设置第二个page元素到

pageElement.setAttribute("name", "content.jsp")//设置page节点的name属性

methodElement = document.createElement_x("method")

methodElement.setTextContent("post")

pageElement.appendChild(methodElement)

displayElement = document.createElement_x("display")

displayElement.setTextContent("content")

pageElement.appendChild(displayElement)

Element url_titleElement = document.createElement_x("url_title") //设置url_title节点

url_titleElement.setTextContent("title,publisher,published_calendar")//给url_title设置值

pageElement.appendChild(url_titleElement)//添加url_title节点到page节点内

root.appendChild(pageElement)//将page段加人根节点内

TransformerFactory transFactory = TransformerFactory.newInstance()//开始把Document映射到文件

Transformer transFormer = transFactory.newTransformer()

DOMSource domSource = new DOMSource(document) //设置输出结果

File file = new File("MobileNetRule.xml")//生成xml文件

if (!file.exists()) {

file.createNewFile()

}

FileOutputStream out = new FileOutputStream(file) //文件输出流

StreamResult xmlResult = new StreamResult(out) //设置输入源

transFormer.transform(domSource, xmlResult) //输出xml文件

System.out.println(file.getAbsolutePath()) //测试文件输出的路径

TransformerFactory tf = TransformerFactory.newInstance()

Transformer t = tf.newTransformer()

t.setOutputProperty("{/encoding/}","GB2312/")

ByteArrayOutputStream boc = new ByteArrayOutputStream()

t.transform(new DOMSource(document), new StreamResult(boc))

String xmlstring = boc.toString()

System.out.println(xmlstring)

} catch (Exception e) {

e.printStackTrace()

}

}

public static void main(String[] args){

Test.generate()

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/tougao/8116325.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-13
下一篇2023-04-13

发表评论

登录后才能评论

评论列表(0条)

    保存