上篇总结了下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. Sublime Text3 配置 NodeJs 环境

    前言 大家都知道,Sublime Text 安装插件一般从 Package Control 中直接安装即可,当我安装 node js 插件时候,直接通过Package Control 安装,虽然插件安 ...

  2. 关于angularjs中的jQuery

    关于angularjs中的jQuery 下面是一个小例子,用来说明我经常看到的一种模式.我们需要一个开关型的按钮.(注意:这个例子的代码有点装逼,并且有点冗长,只是为了用来代表更加复杂一些的例子,这些 ...

  3. 数据结构与算法JavaScript (二) 队列

    队列是只允许在一端进行插入操作,另一个进行删除操作的线性表,队列是一种先进先出(First-In-First-Out,FIFO)的数据结构 队列在程序程序设计中用的非常的频繁,因为javascript ...

  4. 前端MVVM框架avalon揭秘 - 双向绑定原理

    avalon大家可能不熟悉,但是Knockout估计或多或少听过用过,那么说说KO的几个概念 监控属性(Observables)和依赖跟踪(Dependency tracking) 声明式绑定(Dec ...

  5. 理解javascript中的浏览器窗口——窗口基本操作

    × 目录 [1]窗口位置 [2]窗口大小 [3]打开窗口[4]关闭窗口 前面的话 BOM全称是brower object model(浏览器对象模型),主要用于管理窗口及窗口间的通讯,其核心对象是wi ...

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

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

  7. VS2015 Enterprise 安装之惊险及收获

    前言 园子早早的就有人安装了VS 2015,自己也按捺不住了,也要赶快尝尝鲜!结果在其安装过程中一个小小的问题却困扰了我一天,这其中多亏了dudu耐心的解答才得以顺利完成,如果你也遇见这个问题,看过这 ...

  8. Android自定义spinner下拉框实现的实现

    一:前言 本人参考博客:http://blog.csdn.net/jdsjlzx/article/details/41316417 最近在弄一个下拉框,发现Android自带的很难实现我的功能,于是去 ...

  9. 辨析relative与absolute

    谈起它们,想必大家都不陌生.relative,相对定位嘛:absolute,绝对定位嘛.但是它们到底是个啥东东呢? 看看w3c的定义,见下表 定位 含义 relative 元素框偏移某个距离.元素仍保 ...

  10. nodejs与javascript中的aes加密

    简介 1.aes加密简单来说,在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准.这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用.高级加密标准已然成为对称密钥加 ...