J2ME学习系列之如何将J2ME与XML集成

1、XML(Extensible Markup Language)可扩展标记语言??XML独立于硬件和软件,XML文件和HTML文件一样,实际上是一个文本文件。创建XML文件最普通的工具和HTML一样,就是“记事本”了。除了“记事本”之外,当然还有一些更加方便的工具,如XML Notepad、XML Pro、CLIP、XML SPY等,这些工具的一大特点是:能够检查你所建立的XML文件是否符合XML规范。

2、为了访问XML文件,J2ME工具箱必须包含一个XML分析程序,适用于移动设备的XML分析程序优势在于:不用消耗大量的内存(占用内存较少)。

3、适用于移动设备的XML分析程序有以下几种:(XML分析程序需要从Internet上下载)

KXML MinXML NanoXML  TinyXML

4、分析XML文件有两种方法:基于事件的和基于树的。

基于事件的XML分析程序??单独分析XML文件中的每个元素,并通过回调方法把分析的数据送到MIDlet应用。

基于树的XML分析程序??相反读入整个XML文件到一种内部的树结构,把此文件存储在移动设备的内存中,缺点是带来设备上很大的内存开销,优点是快而方便地导航和操纵已分析的数据。

5、一个实例??用基于树的XML分析程序连接MIDlet到XML文件。

1)首先需要一个TinyXML分析程序,可从Internet上下载,该程序是一个.jar的包,实际上就是一个java的类库(很小15KB)。

2)下载完后把TinyXML分析程序放到X:\WTK104\apps\ProjectName\lib中。

3)XML文件内容如下:

<?xml version="1.0" ?>
<mail>
<From>Developer</From>
<To>Students</To>
<Cc>Faculty</Cc>
<Date>30 </Date>
<Subject>Integration</Subject>
<Body Language="English">
This is J2ME!!!!!!
</Body>
</mail>

另存为mail.xml,你也可以使用自己的XML文件??把该文件放如J2EE服务器的public_html文件夹中。

4)MIDlet应用代码如下:

import java.io.*;
import java.util.*;
import java.lang.String;
import javax.microedition.lcdui.*;
import javax.microedition.io.*;
import javax.microedition.midlet.*;
//下面两个包出现在XML分析程序tinyTreeDemo中
import gd.xml.*;
import gd.xml.tiny.*;
public class tinyTreeDemo extends
MIDlet implements CommandListener
{
private String url;
private ParsedXML root;
private Display myDisplay=null;
private Form mainScreen;
private TextField requestField;
Command sendCommand=new Command
("SEND",Command.OK,1);
public tinyTreeDemo()
{
//放置mail.xml文件的Web站点
url="http://127.0.0.1:8000/mail.xml";
myDisplay=Display.getDisplay(this);
mainScreen=new Form("Type a URL:");
requestField=new TextField
(null,url,100,TextField.URL);
mainScreen.append(requestField);
mainScreen.addCommand(sendCommand);
mainScreen.setCommandListener(this);
}
public void startApp()
throws MIDletStateChangeException
{
myDisplay.setCurrent(mainScreen);
    }
    public void pauseApp()
    {
    }
public void destroyApp
(boolean unconditional)
    {
    }
public void commandAction
(Command c,Displayable s)
    {
if(c==sendCommand)
        {
String urlString=
requestField.getString();
try
{
//返回XML根元素
root=TinyParser.parseXML(url);
displayNode(root);
}
catch(ParseException e)
{
System.err.println("startApp:" + e);
}
        }
    }
private void displayNode
(ParsedXML px)
    {
//返回节点对象类型
String nodeName=px.getTypeName();
//返回节点对象类型+名称,例如tag<mail>,
tag为类型(标签),mail为节点名
if(px.getName()!=null)
nodeName+="<" + px.getName() + ">";
//返回存储在标签之间的内容
String nodeContent=px.getContent();
if(nodeContent==null)
nodeContent="";
//在控制台中打印出来
System.out.println(nodeName + ":");
System.out.println(nodeContent);
Enumeration e;
//返回属性,如果有就存储在Enumeration中
e=px.attributes();
if(e.hasMoreElements())
{
System.out.print("attribute:");
while(e.hasMoreElements())
{
//返回属性名称
String attrName=(String)e.nextElement();
//px.getAttribute(attrName)返回属性的值
System.out.println(attrName +
":" + px.getAttribute(attrName));
}
}
//返回节点中的元素,
如果有就存储在Enumeration中
e=px.elements();
if(e.hasMoreElements())
{
//显示下一个节点
while(e.hasMoreElements())
displayNode(
(ParsedXML)e.nextElement());
}
    }
}

时间: 2024-11-18 13:25:38

J2ME学习系列之如何将J2ME与XML集成的相关文章

J2ME学习——从模拟器到真机

J2ME学习--从模拟器到真机 作者:陈跃峰 出自:http://blog.csdn.net/mailbomb          对于J2ME开发者来说,模拟器给我们带来了很多方便,比如可以在模拟器中调试程序以及很方便的察看程序的效果,但是模拟器也给我们带来了一些问题,比如模拟器实现的bug等等,所以进行真机测试是必须的. 1.  为什么要进行真机测试? 因为模拟器程序可能存在bug,以及真机的性能有限,所以必须进行真机测试. 2.  如何将程序传输到机器中? 将程序传输到机器中有如下方式: a

J2ME学习——从WTK到厂商SDK

J2ME学习--从WTK到厂商SDK 作者:陈跃峰 出自:http://blog.csdn.net/mailbomb          对于J2ME爱好者来说,基本上大家都是从SUN的WTK(J2ME Wireless Toolkit)开始的,但是对于实际应用来说,仅仅使用WTK是远远不够的,所以在学习过程中,必须完成从WTK到SDK的跨越. 1.  厂商SDK的下载地址? http://blog.csdn.net/Mailbomb/archive/2005/01/01/236606.aspx

ExtJs2.0学习系列(2)--Ext.Panel

上一篇文章ExtJs2.0学习系列(1)--Ext.MessageBox ,受到了大家的褒贬不一,还是有的朋友提出好的建议,在此表示感谢! 今天介绍extjs中的Panel组件. //html代码 <div id="container"> </div> //js代码 var p = new Ext.Panel({ title: 'My Panel',//标题 collapsible:true,//右上角上的那个收缩按钮,设为false则不显示 renderTo:

ExtJs2.0学习系列(6)--Ext.FormPanel之第三式(ComboBox篇)

前言:说句实话,此extjs系列的文章在博客园中的热度不高,可能是学这玩意的人不多吧,但是我觉得有这么个系列的文章对于中国朋友非常有帮助!请大家支持! 上篇ExtJs2.0学习系列(5)--Ext.FormPanel之第二式中我们讨论了下fieldset和表单验证的知识,今天我们接着深入解析表单元素中ComboBox组件的使用.会涉及 到.net简单服务器数据交互,但暂不做深入讨论,以后会详细分析服务器交互相关,不过可能要等较长一段时间,呵呵! 5.服务器数据作为ComboBox的数据源实例 首

JAVA/JSP学习系列之八(改写MySQL翻页例子)

js|mysql|翻页 一.前言 其实,改写后的JDBC Data-Source是运行在Servlet中的,通过JNDI去查找数据源.我用Orion试的,将本站<JAVA/JSP学习系列之六(MySQL翻页例子) > 简单改写了一下. 二.配置 (1)JDBC 需要将用到的JDBC驱动Copy到[ORION]/lib目录下 (2)data-source 在[ORION]/config/data-sources.xml文件中加入如下: 〈data-source class="com.e

ExtJs2.0学习系列

ExtJs2.0学习系列(15)--extjs换肤 ExtJs2.0学习系列(14)--Ext.TreePanel之第三式(可增删改的树) ExtJs2.0学习系列(13)--Ext.TreePanel之第二式 ExtJs2.0学习系列(12)--Ext.TreePanel之第一式 ExtJs2.0学习系列(11)--Ext.XTemplate ExtJs2.0学习系列(10)--Ext.TabPanel之第二式 ExtJs2.0学习系列(9)--Ext.TabPanel之第一式 ExtJs2.

ExtJs2.0学习系列(12)--Ext.TreePanel之第一式

今天开始,我们就开始一起学习TreePanel了,道个歉,上篇的代码很乱阿. 我总是喜欢用最简单的例子开始,去理解最基本的使用方法,减少对i后面高级使用的干扰! TreePanel是继承自Panel,所以很多在Panel中谈到的属性这里可能会一笔带过,如有问题,请参考ExtJs2.0学习系列(2)--Ext.Panel 1.第一个静态树--最简单的树 效果图: html代码: <div id="container"> </div> js代码: Ext.onRea

ExtJs2.0学习系列(3)--Ext.Window

前面介绍了panel组件--ExtJs2.0学习系列(2)--Ext.Panel,今天将介绍window组件,它继承自panel. 先介绍个最简单例子 //html代码 <div id="win" class="x-hidden"> </div> //js代码 var w=new Ext.Window({ contentEl:"win",//主体显示的html元素,也可以写为el:"win" width

Gradle学习系列之一——Gradle快速入门(转)

  这是一个关于Gradle的学习系列,其中包含以下文章: Gradle快速入门 创建Task的多种方法 读懂Gradle语法 增量式构建 自定义Property 使用java Plugin 依赖管理 构建多个Project 自定义Task类型 自定义Plugin   请通过以下方式下载本系列文章的Github示例代码: git clone https://github.com/davenkin/gradle-learning.git     和Maven一样,Gradle只是提供了构建项目的一