Android应用中使用XmlSerializer序列化XML数据的教程

首先,我们看一下什么是serializer,serializer就是串行化,又名序列化。它可并不只是简单的把对象保存在存储器上,它可以使我们在流中传输对象,使对象变的可以像基本数据一样传递。
XmlSerializer是针对XML进行序列化的类库,我们先来看一下里面的常用方法:

基本方法
1.创建一个xml文件的序列化器,返回的是一个Xml的 Serializer 对象。

XmlSerializer = Xml.newSerializer();

2.设置序列化器的输出路径和编码方式

FileOutputStream = new FileOutputStream(new File(Environment.getExternalStorageDirectory(),"文件名.xml"));
XmlSerializer.setOutput(FileOutputStream, "编码");

3.声明xml文件头(写入XML文件中的声明头)

serializer.startDocument("xml声明的编码", 文档是否独立);

4.声明子节点

Serializer.startTag(nameSpace,String "节点名");

5.声明节点属性

Serializer.attribute(命名空间,属性名,属性值);

6.声明节点中的TextNode

Serializer.txt(文本值);

7.设置节点尾标签

Serializer.endTag(命名空间, "节点名");

8.写Xml文件尾表示Xml文件结束。

Serializer.endDocument();

9.关闭资源

FileOutputStream.close();

示例

最终效果图如上
现在粘贴主要代码:

main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  >
<TextView
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:id="@+id/textView"
  />
</LinearLayout>

activity的代码

package cn.com.xmlseriliazer; 

import java.io.StringWriter;
import java.util.ArrayList; 

import org.xmlpull.v1.XmlPullParserFactory;
import org.xmlpull.v1.XmlSerializer; 

import android.app.Activity;
import android.os.Bundle;
import android.widget.TextView;
/**
 *
 * @author chenzheng_java
 * @description 测试通过XmlSerilizer生成xml文件
 * @since 2011/03/03
 *
 */
public class XmlSerializerActivity extends Activity {
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main); 

    String result = produceXml();
    TextView textView = (TextView)this.findViewById(R.id.textView);
    textView.setText(result); 

  }
  /**
   *
   * @return 生成的xml文件的字符串表示
   */
  private String produceXml(){ 

    StringWriter stringWriter = new StringWriter();
    ArrayList<Beauty> beautyList = getData();
    try {
      // 获取XmlSerializer对象
      XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
      XmlSerializer xmlSerializer = factory.newSerializer();
      // 设置输出流对象
      xmlSerializer.setOutput(stringWriter);
      /*
       * startDocument(String encoding, Boolean standalone)encoding代表编码方式
       * standalone 用来表示该文件是否呼叫其它外部的文件。
       * 若值是 ”yes” 表示没有呼叫外部规则文件,若值是 ”no” 则表示有呼叫外部规则文件。默认值是 “yes”。
       */
      xmlSerializer.startDocument("utf-8", true);
      xmlSerializer.startTag(null, "beauties");
      for(Beauty beauty:beautyList){
        /*
         * startTag (String namespace, String name)这里的namespace用于唯一标识xml标签
         *XML 命名空间属性被放置于某个元素的开始标签之中,并使用以下的语法:
          xmlns:namespace-prefix="namespaceURI"
          当一个命名空间被定义在某个元素的开始标签中时,所有带有相同前缀的子元素都会与同一个命名空间相关联。
          注释:用于标示命名空间的地址不会被解析器用于查找信息。其惟一的作用是赋予命名空间一个惟一的名称。不过,很多公司常常会作为指针来使用命名空间指向某个实存的网页,这个网页包含着有关命名空间的信息。
         */
        xmlSerializer.startTag(null, "beauty"); 

        xmlSerializer.startTag(null, "name");
        xmlSerializer.text(beauty.getName());
        xmlSerializer.endTag(null, "name"); 

        xmlSerializer.startTag(null, "age");
        xmlSerializer.text(beauty.getAge());
        xmlSerializer.endTag(null, "age"); 

        xmlSerializer.endTag(null, "beauty");
      }
      xmlSerializer.endTag(null, "beauties");
      xmlSerializer.endDocument();
    } catch (Exception e) {
      e.printStackTrace();
    }
    return stringWriter.toString(); 

  } 

  /**
   *
   * @return 包含了众多美女信息的集合
   */
  private ArrayList<Beauty> getData(){
    ArrayList<Beauty> beautyList = new ArrayList<Beauty>(); 

    Beauty yangmi = new Beauty("杨幂", "23");
    Beauty linzhiling = new Beauty("林志玲", "28"); 

    beautyList.add(yangmi);
    beautyList.add(linzhiling); 

    return beautyList;
  } 

  /**
   *
   * @author chenzheng_java
   * 美人实体类
   */
  private class Beauty{
    String name;
    String age ;
    public String getName() {
      return name;
    }
    public void setName(String name) {
      this.name = name;
    }
    public String getAge() {
      return age;
    }
    public void setAge(String age) {
      this.age = age;
    }
    @Override
    public String toString() {
      return "Beauty [age=" + age + ", name=" + name + "]";
    }
    public Beauty(String name, String age) {
      this.name = name;
      this.age = age;
    }
    public Beauty(){ 

    } 

  } 

}

其他都为默认。

由代码我们可以看到,其实使用xmlserializer生成xml也是相当容易的。基本的步骤和解析xml差不多。这里就不多说话了。详情请看api。

(0)

相关推荐

  • Android xml文件的序列化实现代码

    传统方式: 复制代码 代码如下: public void backSms(View view){  //假设我已经获取到了所有的短信  StringBuilder sb = new StringBuilder();  sb.append("<?xml version=\"1.0\" encoding=\"utf-8\"?>");  sb.append("<smss>");  for(SmsInfo in

  • Android 序列化的存储和读取总结及简单使用

           Android 序列化 1.序列化的目的 (1).永久的保存对象数据(将对象数据保存在文件当中,或者是磁盘中 (2).通过序列化操作将对象数据在网络上进行传输(由于网络传输是以字节流的方式对数据进行传输的.因此序列化的目的是将对象数据转换成字节流的形式) (3).将对象数据在进程之间进行传递(Activity之间传递对象数据时,需要在当前的Activity中对对象数据进行序列化操作.在另一个Activity中需要进行反序列化操作讲数据取出) (4).Java平台允许我们在内存中创建

  • Android中的序列化浅析

    序列化原因 序列化的原因基本可以归纳为以下三种情况: 1.永久性保存对象,保存对象的字节序列到本地文件中: 2.对象在网络中传递: 3.对象在IPC间传递. 序列化方法 在Android系统中关于序列化的方法一般有两种,分别是实现Serializable接口和Parcelable接口,其中Serializable接口是来自Java中的序列化接口,而Parcelable是Android自带的序列化接口. 上述的两种序列化接口都有各自不同的优缺点,我们在实际使用时需根据不同情况而定. 1.Seria

  • Android中Serializable和Parcelable序列化对象详解

    本文详细对Android中Serializable和Parcelable序列化对象进行学习,具体内容如下 学习内容: 1.序列化的目的 2.Android中序列化的两种方式 3.Parcelable与Serializable的性能比较 4.Android中如何使用Parcelable进行序列化操作 5.Parcelable的工作原理 6.相关实例  1.序列化的目的 1).永久的保存对象数据(将对象数据保存在文件当中,或者是磁盘中 2).通过序列化操作将对象数据在网络上进行传输(由于网络传输是以

  • Android中的Parcelable序列化对象

    今天查阅资料,简单了解了一下Parcelable接口,它是android提供的序列化对象的接口,比java中的 Serializable高效些.通过这个接口序列化对象主要有两步: 1.实现public void writeToParcel(Parcel dest, int flags) {}方法: 2.实例化CREATOR public static final Parcelable.Creator<ParcelableImpl> CREATOR = new Parcelable.Creato

  • Android序列化XML数据

    什么是XML?首先我们先了解一下什么是XML.XML,可扩展标记语言 (Extensible Markup Language) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据.定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言,这是百度百科的解释.而XML是一种在Internet中传输数据的常见格式,它与HTML一样,都是SGML(标准通用标记语言),无论你是需要通过Internet访问数据,或者发送数据给Web服务,都可能需要用到XML的知识.恰恰Android应用程序

  • 解析Android中的Serializable序列化

    1.为何要序列化? -- 把内存中的java对象能够在磁盘上持久保存 -- 通过网络传输对象 -- 通过RMI(Remote Method Invocation 远程过程调用)传输. 通过序列化可以把对象转化为与平台无关的二进制流,在重新使用前进行反序列化,重新转化为java对象. (远程过程调用针对分布式Java应用,对开发人员屏蔽不同JVM和网络连接等细节,是的分布在不同JVM上的对象似乎存在于一个统一的JVM中,能够方便的通讯) 2.如何让Java对象可以被序列化? 在java里只需让目标

  • 很详细的android序列化过程Parcelable

    直接上代码:注释都写的很清楚了. public class Entry implements Parcelable{ public int userID; public String username; public boolean isMale; public Book book;//序列化对象可以嵌套序列化对象,前提是2个类的对象都被序列号过 //几乎所有情况下都返回0,可以不管 @Override public int describeContents() { return 0; } //

  • Android应用中使用XmlSerializer序列化XML数据的教程

    首先,我们看一下什么是serializer,serializer就是串行化,又名序列化.它可并不只是简单的把对象保存在存储器上,它可以使我们在流中传输对象,使对象变的可以像基本数据一样传递. XmlSerializer是针对XML进行序列化的类库,我们先来看一下里面的常用方法: 基本方法 1.创建一个xml文件的序列化器,返回的是一个Xml的 Serializer 对象. XmlSerializer = Xml.newSerializer(); 2.设置序列化器的输出路径和编码方式 FileOu

  • Android开发中Listview动态加载数据的方法示例

    本文实例讲述了Android开发中Listview动态加载数据的方法.分享给大家供大家参考,具体如下: 最近在研究网络数据加载的问题,比如我有几百,甚至上千条数据,这些数据如果一次性全部加载到arraylist,然后再加载到Listview中.我们必然会去单独开线程来做,这样造成的结果就是会出现等待时间很长,用户体验非常不好.我的想法是动态加载数据,第一次加载十条,然后往下面滑动的时候再追加十条,再往下面滑动的时候再去追加,这样大大减少了用户等待的时间,同时给处理数据留下了时间.网上看到了这样一

  • Android应用中使用SharedPreferences类存储数据的方法

    在Android系统中提供了多种存储技术.通过这些存储技术可以将数据存储在各种存储介质上.比如sharedpreferences可以将数据保存着应用软件的私有存储区,这些存储区的数据只能被写入这些数据的软件读取.当然Android还支持文件存储.SQLite数据库和Content Provider.在这里我们将对sharedpreferences存储方式进行介绍. SharedPreferences是一种轻量级的数据存储方式,学过Web开发的同学,可以想象它是一个小小的Cookie.它可以用键值

  • Android解析服务器端发来的xml数据示例

    Android跟服务器交互数据,有时数据量大时,就需要以xml形式的交互数据.这里来实现服务器给Android客户端发送xml数据,Android客户端解析. 服务器端我使用dom4j第三方包来组织xml数据,大家可自行百度下载.而Android客户端则使用 XmlPullParser来解析xml数据. 服务器端代码: 复制代码 代码如下: package servlet; import java.io.IOException; import java.io.PrintWriter; impor

  • Android系统中使用shareuserid获取系统权限的教程

    Android会为每个apk进程分配一个单独的空间(比如只能访问/data/data/自己包名下面的文件),一般情况下apk之间是禁止相互访问数据的.通过Shared User id,拥有同一个User id的多个APK可以配置成运行在同一个进程中.所以默认就是可以互相访问任意数据. 也可以配置成运行成不同的进程, 同时可以访问其他APK的数据目录下的数据库和文件.就像访问本程序的数据一样(使用IPC机制,不同进程之间,比如AIDL). 一.使用同一个shareuserid,多个apk运行到同一

  • Android Studio中配置OpenCV库开发环境的教程

    1.下载 进入官网(http://opencv.org/)下载OpenCV4Android并解压.目录结构如下图所示. 其中,sdk目录即是我们开发opencv所需要的类库:samples目录中存放着若干opencv应用示例(包括人脸检测等),可为我们进行android下的opencv开发提供参考:doc目录为opencv类库的使用说明及api文档等:而apk目录则存放着对应于各内核版本的OpenCV_2.4.3.2_Manager_2.4应用安装包.此应用用来管理手机设备中的opencv类库,

  • Android App中使用Pull解析XML格式数据的使用示例

    Pull解析XML文件的方式与SAX解析XML文件的方式大致相同,他们都是基于事件驱动的.所以,利用pull解析XML文件需要下面几个步骤: 1)通过XMLPullParserFactory获取XMLPullParser对象. 2)通过XMLPullParser对象设置输入流. 3)通过parser.next(),持续的解析XML文件直到文件的尾部. 下面的几个方法是经常需要的:XMLPullParserFacotry.newInstance( )    facotry.newPullParse

  • 解析Java的Jackson库中对象的序列化与数据泛型绑定

    Jackson对象序列化 这里将介绍将Java对象序列化到一个JSON文件,然后再读取JSON文件获取转换为对象.在这个例子中,创建了Student类.创建将有学生对象以JSON表示在一个student.json文件. 创建一个名为JacksonTester在Java类文件在 C:\>Jackson_WORKSPACE. 文件: JacksonTester.java import java.io.File; import java.io.IOException; import org.codeh

  • PHP中使用xmlreader读取xml数据示例

    有一个XML文件,内容如下: 复制代码 代码如下: <?xml version="1.0"?>  <shows>      <show>          <name>Simpsons</name>          <channel>FOX</channel>          <start>8:00 PM</start>          <duration>30

随机推荐