- wuhua
- 等级:


- 性别:

- 文章: 546
- 积分: 1457
- 来自: 广州

|
这几天一直在思考怎么样设计Wap的引擎。因为在j2me有限的资源上去解释xml是比较慢的,所以j2se上的xml类库是不适合用在j2me上,后来在网上查找了下发现了XmlPullParser ,而且用起来速度快,而且包也很小。现在把这两天学到的知识记录下来。
我的需求是解释一个标准的wml。比如:
xml 代码
- <?xml version="1.0"?>
- <!DOCTYPE wml PUBLIC "-//WAPFORUM//DTD WML 1.1//EN" "http://www.wapforum.org/DTD/wml_1.1.xml">
- <wml>
- <card id="index" title="天速">
- <p align="center">天速科技</p>
- <p align="center"><a href="http://wap.gd.monternet.com/reversesubscribe?SPID=819758&ServiceID=03020047"> 动漫天下 </a></p>
- <p align="center"><a href="http://wap.gd.monternet.com/reversesubscribe?SPID=819758&ServiceID=03020048&SPURL=http://211.155.31.143/t/viewPic.a?picId=1308"> 国色天香 </a></p>
- <p align="center"><a href="http://wap.gd.monternet.com/reversesubscribe?SPID=819758&ServiceID=04070717&SPURL=http://211.155.31.143/eb/allBook.a"> 风月书斋 </a></p>
-
- </card> </wml>
上面是个简单的wml源文件。不过现在的wap网站差不都这样,基本上没有script,跟html上的各个控件。所以能解释上面的文档,基本上都是可以满足我的需求的。
现在我们来看下我们解释wml的java文件
java 代码
-
-
-
-
-
-
-
-
- import java.io.ByteArrayInputStream;
- import java.io.IOException;
- import java.io.InputStreamReader;
-
- import org.kxml2.io.KXmlParser;
- import org.xmlpull.v1.XmlPullParser;
- import org.xmlpull.v1.XmlPullParserException;
- import org.xmlpull.v1.XmlPullParserFactory;
-
-
-
-
-
-
-
-
- public class Test {
-
-
-
-
- private static String xml =""
- +"
- +"\"http://www.wapforum.org/DTD/wml_1.1.xml\">"
- +""
- +""
- +"
天速科技
"
- +"
动漫天下
"
- 动漫天下
"
- +"
国色天香
"
- +"
风月书斋
"
- 风月书斋
"
-
- +" ";
- public static void main(String args[])
-
- throws XmlPullParserException, IOException {
-
-
- ByteArrayInputStream bin = new ByteArrayInputStream(xml.getBytes());
- InputStreamReader in = new InputStreamReader(bin);
- KXmlParser parser = new KXmlParser();
- parser.setInput(in);
-
- int eventType = parser.getEventType();
- while (eventType != XmlPullParser.END_DOCUMENT) {
- if (eventType == XmlPullParser.START_DOCUMENT) {
-
- } else if (eventType == XmlPullParser.END_DOCUMENT) {
-
- } else if (eventType == XmlPullParser.START_TAG) {
- System.out.println(" " + parser.getName());
-
- int size = parser.getAttributeCount();
- for(int i=0; i
- System.out.println(" " + parser.getAttributeName(i));
- System.out.println(" " + parser.getAttributeValue(i));
- }
-
-
- } else if (eventType == XmlPullParser.END_TAG) {
- System.out.println(" " + parser.getName());
- } else if (eventType == XmlPullParser.TEXT) {
- System.out.println(" " + parser.getText());
- }
- eventType = parser.next();
- }
- }
-
- }
现在解释下上面的东西,
XmlPullParser 只是个规范,可以到 http://xmlpull.org/ 下载。我们来看看这个规范要求我们做些什么。
里面主要的方法有
java 代码
-
- public int getEventType() throws XmlPullParserException ;
-
- public int next() throws XmlPullParserException, IOException
-
- public String getName();
-
- public String getText();
-
-
- public int getAttributeCount() ;
-
- public String getAttributeName(int index);
-
-
- public String getAttributeValue(int index);
我们理解了XmlPullParser 可以自己实现一个XmlPullParser。不过java世界里好东西就是多。已经有人帮我们做了。
啊就是kxml。
这个API本身很简单。当时要把一个完整的wml解释并绘制在手机上还是要花相当的时间的。
声明:JavaEye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
|
| 返回顶楼 |
|
|
- 为你而来
- 等级: 初级会员

- 性别:

- 文章: 25
- 积分: 65
- 来自: 广州

|
支持,继续努力!!!!
|
| 返回顶楼 |
|
|
- taowen
- 等级:


- 性别:

- 文章: 348
- 积分: 1294
- 来自: 北京

|
pull parser为什么快?sax parser为什么慢?我觉得这是关键。我曾经在delphi上把一个sax parser改装成pull parser。其实很简单,只要把回调的API改成基于循环的主动查询。做的是减法。
|
| 返回顶楼 |
|
|
- alin_ass
- 等级:


- 性别:

- 文章: 175
- 积分: 602
- 来自: 杭州

|
我用kml实现过类似burlap的玩意,现在JDK6.0已经有实现了StAX(JSR 173)
不过这一块挺适合重复造轮子的,我原来碰到就是公司有xml协议不是规范的,比如<class#>什么这种,就自己改kml
|
| 返回顶楼 |
|
|
- wuhua
- 等级:


- 性别:

- 文章: 546
- 积分: 1457
- 来自: 广州

|
在设计的过程中发现容错性是很重要的。 我现在就遇到这个问题,解释wml的时候,遇到 这些特殊符合就抛出异常。很是郁闷。主要的是kml抛出异常后,就停止解释了。要改装下它。不过wml文件是否很标准也一定要解释完毕。就想firefox解释html一样。
|
| 返回顶楼 |
|
|
- tianshui
- 等级: 初级会员

- 文章: 1
- 积分: 2

|
-.-我是初学者
经常关注楼主的帖子 收获很大
|
| 返回顶楼 |
|
|
- wuhua
- 等级:


- 性别:

- 文章: 546
- 积分: 1457
- 来自: 广州

|
哈哈。谢谢关注与支持,我会继续努力搞好自己的blog,并且多与大家交流技术,希望可以相互提高各自的水平,这样可以更深入的去探讨比较东西。
|
| 返回顶楼 |
|
|