上篇总结了下JSON的序列化和反序列化,博园中大牛给了很多牛叉的评论,学习了不少。

不过在上篇中忘了把json序列化和反序列化的另外一种方式写上去了,这里做个简单的补充:

Json篇:http://www.cnblogs.com/zhanghaomars/p/3557644.html

Json序列化和反序列化扩展方法实现类:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Web.Script.Serialization; namespace HelpClass.TypeHelp
{
public static class JsonHelpExpand
{
public static string JsonSerializer<T>(this T t) where T : class
{
JavaScriptSerializer jsonSerialize = new JavaScriptSerializer();
return jsonSerialize.Serialize(t);
} public static T JsonDeserialize<T>(this string jsonString)
{
JavaScriptSerializer jsonSerialize = new JavaScriptSerializer();
return (T)jsonSerialize.Deserialize<T>(jsonString);
}
}
}

Ok!接下来就是XML

1、  静态方法+泛型实现

XML工具类:

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Xml;
using System.Xml.Serialization; namespace HelpClass.TypeHelp
{
public class XMLHelp
{
private static void XmlSerializeInternal(Stream stream, object o, Encoding encoding, bool isnamespaces)
{
if (o == null)
throw new ArgumentNullException("o");
if (encoding == null)
throw new ArgumentNullException("encoding"); XmlSerializer serializer = new XmlSerializer(o.GetType()); XmlWriterSettings settings = new XmlWriterSettings();
settings.Indent = true;
settings.NewLineChars = "\r\n";
settings.Encoding = encoding;
settings.IndentChars = " "; //不生成声明头
settings.OmitXmlDeclaration = !isnamespaces; MemoryStream w = new MemoryStream(); XmlSerializerNamespaces namespaces = new XmlSerializerNamespaces();
namespaces.Add("", ""); using (XmlWriter writer = XmlWriter.Create(stream, settings))
{
serializer.Serialize(writer, o, namespaces);
writer.Close(); }
} /// <summary>
/// 将一个对象序列化为XML字符串
/// </summary>
/// <param name="o">要序列化的对象</param>
/// <param name="encoding">编码方式</param>
/// <param name="isnamespaces">是否需要命名空间true:需要 false:不需要</param>
/// <returns>序列化产生的XML字符串</returns>
public static string XmlSerialize(object o, Encoding encoding, bool isnamespaces)
{
using (MemoryStream stream = new MemoryStream())
{
XmlSerializeInternal(stream, o, encoding, isnamespaces); stream.Position = ;
using (StreamReader reader = new StreamReader(stream, encoding))
{
return reader.ReadToEnd();
}
}
} /// <summary>
/// 从XML字符串中反序列化对象
/// </summary>
/// <typeparam name="T">结果对象类型</typeparam>
/// <param name="s">包含对象的XML字符串</param>
/// <param name="encoding">编码方式</param>
/// <returns>反序列化得到的对象</returns>
public static T XmlDeserialize<T>(string s, Encoding encoding)
{
if (string.IsNullOrEmpty(s))
throw new ArgumentNullException("s");
if (encoding == null)
throw new ArgumentNullException("encoding"); XmlSerializer mySerializer = new XmlSerializer(typeof(T));
using (MemoryStream ms = new MemoryStream(encoding.GetBytes(s)))
{
using (StreamReader sr = new StreamReader(ms, encoding))
{
return (T)mySerializer.Deserialize(sr);
}
}
} /// <summary>
/// 将一个对象按XML序列化的方式写入到一个文件
/// </summary>
/// <param name="o">要序列化的对象</param>
/// <param name="path">保存文件路径</param>
/// <param name="encoding">编码方式</param>
/// <param name="isnamespaces">是否需要命名空间true:需要 false:不需要</param>
public static void XmlSerializeToFile(object o, string path, Encoding encoding, bool isnamespaces)
{
if (string.IsNullOrEmpty(path))
throw new ArgumentNullException("path"); using (FileStream file = new FileStream(path, FileMode.Create, FileAccess.Write))
{
XmlSerializeInternal(file, o, encoding,isnamespaces);
}
} /// <summary>
/// 读入一个文件,并按XML的方式反序列化对象。
/// </summary>
/// <typeparam name="T">结果对象类型</typeparam>
/// <param name="path">文件路径</param>
/// <param name="encoding">编码方式</param>
/// <returns>反序列化得到的对象</returns>
public static T XmlDeserializeFromFile<T>(string path, Encoding encoding)
{
if (string.IsNullOrEmpty(path))
throw new ArgumentNullException("path");
if (encoding == null)
throw new ArgumentNullException("encoding"); string xml = File.ReadAllText(path, encoding);
return XmlDeserialize<T>(xml, encoding);
}
}
}

在一个项目中,如果面临大量的XML(如调用大量返回XML的外部接口),这时就需要根据XML结构来逆向推导C#类型,然后才能使用序列化和反序列化的方法。

当需要根据XML结构逆向推导类型,我们需要了解一下类型定义与XML结构的映射关系。

映射关系只需要记住几个标签:

(1)       [XmlElement]

类中的属性或者字段在不标记下默认都会生成XmlElement(不加任何Attribute的情况下)该标签把类中的属性或者字段序列化为XML中的节点

Public class ddd

{

[XmlElement]

Public string d1{get;set;}

Public string d2{get;set;}

}

ddd cd=new ddd{d1=”1”,d2=”2”}

<ddd><d1>1</d1><d2>2</d2></ddd>

(2)       [XmlAttribute]

类中的属性或者字段在标记为[XmlAttribute]的情况下会生成为XML中以以该类名为节点的属性

Public class ddd

{

[XmlAttribute]

Public string d1{get;set;}

[XmlElement]

Public string d2{get;set;}

}

ddd cd=new ddd{d1=”1”,d2=”2”}

<ddd d1=”1”><d2>2</d2></ddd>

(3)       [InnerText]

如果希望类型中的属性或者字段生成InnerText,需要在类型的成员上用[XmlText]

Public class ddd

{

[XmlAttribute]

Public string d1{get;set;}

[InnerText]

Public string d2{get;set;}

}

ddd cd=new ddd{d1=”1”,d2=”2”}

<ddd d1=”1”>2</ddd>

(4)       重命名

XmlAttribute,XmlElement允许接受一个别名用来控制生成节点的名称,类型的重命名用XmlType来实现

[XmlType(“ccc”)]

Public class ddd

{

[XmlAttribute(“c1”)]

Public string d1{get;set;}

[XmlElement(“c2”)]

Public string d2{get;set;}

}

ddd cd=new ddd{d1=”1”,d2=”2”}

<ccc c1=”1”><c2>2</c2></ccc>

(5)       序列化去掉XML命名空间及声明头(工具类中代码以有相关说明了)

注意:

(1)       当需要考虑使用XML时,先不要想着XML结构,先应该定义好数据类型。

(2)       列表节点不要使用[XmlElement],它会让所有子节点【升级】,显得结构混乱。

(3)       如果希望序列化的XML长度小一点,可以采用[XmlAttribute],或者指定一个更短小的别名(序列化为JSON进行传输也是一种选择)

(4)       不要在一个列表中输出不同的数据类型,这样的XML结构的可读性不好。

(5)       尽量使用UTF-8编码,不要使用GB2312编码。

(6)       列表节点不要使用[XmlElement],它会让所有子节点【升级】,显得结构混乱。

2、  扩展方法+泛型实现

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Xml;
using System.Xml.Serialization; namespace HelpClass.TypeHelp
{
public static class XMLHelpExpand
{
/// <summary>
/// XML序列化
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="o"></param>
/// <param name="isnamespaces">是否需要命名空间true:需要 false:不需要</param>
/// <returns></returns>
public static string XmlSerializer<T>(this T o,bool isnamespaces)where T:class
{
System.Xml.Serialization.XmlSerializer serializer = new System.Xml.Serialization.XmlSerializer(o.GetType()); XmlWriterSettings settings = new XmlWriterSettings();
settings.Indent = true;
settings.NewLineChars = "\r\n";
settings.Encoding = Encoding.UTF8;
settings.IndentChars = " "; //不生成声明头
settings.OmitXmlDeclaration = !isnamespaces; MemoryStream w = new MemoryStream(); XmlSerializerNamespaces namespaces = new XmlSerializerNamespaces();
namespaces.Add("", ""); using (XmlWriter writer = XmlWriter.Create(w, settings))
{
serializer.Serialize(writer, o, namespaces);
writer.Close();
} return Encoding.UTF8.GetString(w.ToArray());
} /// <summary>
/// XML反序列化
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="XmlString"></param>
/// <returns></returns>
public static T XmlDeserialize<T>(this string XmlString)
{
if (string.IsNullOrEmpty(XmlString))
throw new ArgumentNullException("s"); XmlSerializer mySerializer = new XmlSerializer(typeof(T)); using (MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(XmlString)))
{
using (StreamReader sr = new StreamReader(ms, Encoding.UTF8))
{
return (T)mySerializer.Deserialize(sr);
}
}
}
}
}

看完了上面的这些或许你已经对XML的序列化和反序列化有了一定的了解,今天就写到这里,下次总结一下别的。

XML序列化和反序列化的更多相关文章

  1. XML 序列化与反序列化

    XML序列化与反序列化 1.将一个类转化为XML文件 /// <summary> /// 对象序列化成XML文件 /// </summary> /// <param na ...

  2. XmlSerializer 对象的Xml序列化和反序列化

    http://www.cnblogs.com/yukaizhao/archive/2011/07/22/xml-serialization.html 这篇随笔对应的.Net命名空间是System.Xm ...

  3. C#的XML序列化及反序列化

    webservice在工作中用到的很多,基本都是以XML格式问通讯内容,其中最关键的就是XML串的序列化及反序列化. XML的运用中有两种信息传递,一种为XML的请求信息,另一种为返回信息,要运用XM ...

  4. .NET XML序列化与反序列化

    闲着没事,写了两个通用的XML序列化与反序列化的方法. 贴出来当作笔记吧! /// <summary> /// XML序列化 /// </summary> /// <ty ...

  5. XmlSerializer 对象的Xml序列化和反序列化,XMLROOT别名设置

    这篇随笔对应的.Net命名空间是System.Xml.Serialization:文中的示例代码需要引用这个命名空间.   为什么要做序列化和反序列化? .Net程序执行时,对象都驻留在内存中:内存中 ...

  6. c# XML序列化与反序列化

    c# XML序列化与反序列化 原先一直用BinaryFormatter来序列化挺好,可是最近发现在WinCE下是没有办法进行BinaryFormatter操作,很不爽,只能改成了BinaryWrite ...

  7. Xml序列化、反序列化帮助类

    之前从网络上找了一个Xml处理帮助类,并整理了一下,这个帮助类针对Object类型进行序列化和反序列化,而不需要提前定义Xml的结构,把它放在这儿供以后使用 /// <summary> / ...

  8. Windows phone 之XML序列化与反序列化

    为什么要做序列化和反序列化? 一个回答: 我们都知道对象是不能在网络中直接传输的,不过还有补救的办法.XML(Extensible Markup Language)可扩展标记语言,本身就被设计用来存储 ...

  9. C#操作Xml:XmlSerializer 对象的Xml序列化和反序列化

    这篇随笔对应的.Net命名空间是System.Xml.Serialization:文中的示例代码需要引用这个命名空间. 为什么要做序列化和反序列化? .Net程序执行时,对象都驻留在内存中:内存中的对 ...

  10. C#实现接口xml序列化与反序列化

    C#实现接口xml序列化与反序列化   C#中接口无法被xml序列化,提示不支持.百度和bing也搜不到,只好自己动手写了 原理上肯定支持,.Net自己的xml序列化有一个IXmlSerializab ...

随机推荐

  1. Atitit 图像处理知识点体系知识图谱 路线图attilax总结 v4 qcb.xlsx

    Atitit 图像处理知识点体系知识图谱 路线图attilax总结 v4 qcb.xlsx 分类 图像处理知识点体系 v2 qb24.xlsx 分类 分类 理论知识 图像金字塔 常用底层操作 卷积扫描 ...

  2. 冒烟测试 smoking test

    冒烟测试的概念: 版权声明:本文为博主原创文章,未经博主允许不得转载. 冒烟测试既是对软件基本的功能进行测试,测试的对象是每一个新编译的需要正式测试的软件版本,目的是确认软件基本的功能正常,保证软件系 ...

  3. 移动开发--Hybrid和Native混合开发-->HybridApp 、NativeApp、WebApp

    1.1.     APP三种开发模式 智能手机之普及不用多说,手机APP渗投到各个行业:电商(淘宝.京东等).金融(各手机行业.P2P借贷等).医疗(智慧医疗).交通(滴滴.Uber等).教育(慕课网 ...

  4. HTML 最简单的tips 怎么支持指定DIV显示提示信息

    <body> <style type="text/css"> a.link{position:relative;} a.link div.tips{ bor ...

  5. 有吧友需要PDF的下载站点,好吧,我这边汇总一下

    [经验]谈谈怎么找自己想要的资源吧~ http://www.cnblogs.com/dunitian/p/4715482.html PDF Free Computer, Programming, Ma ...

  6. Visulalize Boost Voronoi in OpenSceneGraph

    Visulalize Boost Voronoi in OpenSceneGraph eryar@163.com Abstract. One of the important features of ...

  7. Android探索之ContentProvider熟悉而又陌生的组件

    前言: 总结这篇文章之前我们先来回顾一下Android Sqlite数据库,参考文章:http://www.cnblogs.com/whoislcj/p/5506294.html,Android程序内 ...

  8. C#由变量捕获引起对闭包的思考

    前言 偶尔翻翻书籍看看原理性的东西确实有点枯燥,之前有看到园中有位园友说到3-6年工作经验的人应该了解的.NET知识,其中就有一点是关于C#中的闭包,其实早之前在看书时(之前根本不知道C#中还有闭包这 ...

  9. # Hawk:开源贡献计划,设计,反思

    Hawk在发布之后,收到了不少朋友的感谢和使用反馈,沙漠君表示非常开心.软件肯定有很多的问题和不足,还有很多可扩展的空间,因此我希望更多的朋友,能够参与到改进Hawk的计划中来,为开源世界作出努力. ...

  10. Git版本控制Windows版快速上手

    说到版本控制,之前用过VSS,SVN,Git接触不久,感觉用着还行.写篇博文给大家分享一下使用Git的小经验,让大家对Git快速上手. 说白了Git就是一个控制版本的工具,其实没想象中的那么复杂,咱在 ...