当前位置: 代码迷 >> 综合 >> XmlPullParser 的例子
  详细解决方案

XmlPullParser 的例子

热度:81   发布时间:2023-12-09 08:07:23.0
这几天一直在思考怎么样设计Wap的引擎。因为在j2me有限的资源上去解释xml是比较慢的,所以j2se上的xml类库是不适合用在j2me上,后来在网上查找了下发现了XmlPullParser ,而且用起来速度快,而且包也很小。现在把这两天学到的知识记录下来。

我的需求是解释一个标准的wml。比如:
xml 代码
  1. <?xml version="1.0"?>  
  2. <!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN" "http://www.wapforum.org/DTD/wml_1.1.xml">  
  3. <wml>  
  4. <card id="index" title="天速">  
  5. <p align="center">天速科技</p>  
  6. <p align="center"><a href="http://wap.gd.monternet.com/reversesubscribe?SPID=819758&amp;ServiceID=03020047"> 动漫天下 </a></p>  
  7. <p align="center"><a href="http://wap.gd.monternet.com/reversesubscribe?SPID=819758&amp;ServiceID=03020048&amp;SPURL=http://211.155.31.143/t/viewPic.a?picId=1308"> 国色天香 </a></p>  
  8. <p align="center"><a href="http://wap.gd.monternet.com/reversesubscribe?SPID=819758&amp;ServiceID=04070717&amp;SPURL=http://211.155.31.143/eb/allBook.a">  风月书斋 </a></p>  
  9.   
  10. </card> </wml>  

上面是个简单的wml源文件。不过现在的wap网站差不都这样,基本上没有script,跟html上的各个控件。所以能解释上面的文档,基本上都是可以满足我的需求的。

现在我们来看下我们解释wml的java文件
java 代码
  1. /********************************************************************
  2. * 项目名称 :j2me学习 J2me Wap Explorer
  3. *
  4. * Copyright 2005-2006 Wuhua. All rights reserved
  5. *
  6. * 本程序只用于学习目的,不能用于商业目的。如有需要请联系作者
  7. ********************************************************************/
  8. import java.io.ByteArrayInputStream;
  9. import java.io.IOException;
  10. import java.io.InputStreamReader;
  11. import org.kxml2.io.KXmlParser;
  12. import org.xmlpull.v1.XmlPullParser;
  13. import org.xmlpull.v1.XmlPullParserException;
  14. import org.xmlpull.v1.XmlPullParserFactory;
  15. /**
  16. * 类名:Test.java
    编写日期: 2006-12-28
    程序功能描述:
    Demo:
  17. * Bug:
  18. *
  19. * 程序变更日期 :
    变更作者 :
    变更说明 :
  20. *
  21. * @author wuhua
    rrq12345@163.com
  22. */
  23. public class Test {
  24. //private static String xml = " <list><item>apple</item>"</list>
  25. // + "<item>orange</item>" + "<item>pear</item>";
  26. private static String xml =""
  27. +"
  28. +"\"http://www.wapforum.org/DTD/wml_1.1.xml\">"
  29. +"<wml>"</wml>
  30. +"<card title="\&quot;天速\&quot;" id="\&amp;quot;index\&quot;">"</card>
  31. +"

    天速科技

    "
  32. +"

    动漫天下

    "
  33. +"

    国色天香

    "
  34. +"

    风月书斋

    "
  35. +" ";
  36. public static void main(String args[])
  37. throws XmlPullParserException, IOException {
  38. ByteArrayInputStream bin = new ByteArrayInputStream(xml.getBytes());
  39. InputStreamReader in = new InputStreamReader(bin);
  40. KXmlParser parser = new KXmlParser();
  41. parser.setInput(in);
  42. int eventType = parser.getEventType();
  43. while (eventType != XmlPullParser.END_DOCUMENT) {
  44. if (eventType == XmlPullParser.START_DOCUMENT) {
  45. //System.out.println("Start document:");
  46. } else if (eventType == XmlPullParser.END_DOCUMENT) {
  47. //System.out.println("End document");
  48. } else if (eventType == XmlPullParser.START_TAG) {
  49. System.out.println(" " + parser.getName());
  50. //System.out.println("Start Count: " + parser.getAttributeCount());
  51. int size = parser.getAttributeCount();
  52. for(int i=0; i
  53. System.out.println(" " + parser.getAttributeName(i));
  54. System.out.println(" " + parser.getAttributeValue(i));
  55. }
  56. } else if (eventType == XmlPullParser.END_TAG) {
  57. System.out.println(" " + parser.getName());
  58. } else if (eventType == XmlPullParser.TEXT) {
  59. System.out.println(" " + parser.getText());
  60. }
  61. eventType = parser.next();
  62. }
  63. }
  64. }

现在解释下上面的东西,
XmlPullParser 只是个规范,可以到 http://xmlpull.org/ 下载。我们来看看这个规范要求我们做些什么。
里面主要的方法有
java 代码
  1. //定义一个事件采用回调的方式,直到读取xml完毕。
  2. public int getEventType() throws XmlPullParserException ;
  3. //遍历下一个事件,返回一个事件的类型
  4. public int next() throws XmlPullParserException, IOException
  5. //得到当前Tag名字
  6. public String getName();
  7. //获取文本
  8. public String getText();
  9. //得到当前Tag下面的属性数量
  10. public int getAttributeCount() ;
  11. //得到当前Tag下面指定位置的属性名称
  12. public String getAttributeName(int index);
  13. //得到当前Tag下面指定位置的属性植
  14. public String getAttributeValue(int index);

我们理解了XmlPullParser 可以自己实现一个XmlPullParser。不过java世界里好东西就是多。已经有人帮我们做了。
啊就是kxml。
这个API本身很简单。当时要把一个完整的wml解释并绘制在手机上还是要花相当的时间的。