XML序列化后,反序列化时出现错误

报错现象

System.InvalidOperationException: XML 文档(40, 11)中有错误。 ---> System.Xml.XmlException: 根级别上的数据无效。 第 40 行,位置 11。
在 System.Xml.XmlTextReaderImpl.Throw(Exception e)
在 System.Xml.XmlTextReaderImpl.ParseRootLevelWhitespace()
在 System.Xml.XmlTextReaderImpl.ParseDocumentContent()
在 System.Xml.XmlReader.ReadEndElement()
在 Microsoft.Xml.Serialization.GeneratedAssembly.XmlSerializationReaderConfigs.Read3_Configs(Boolean isNullable, Boolean checkType)
在 Microsoft.Xml.Serialization.GeneratedAssembly.XmlSerializationReaderConfigs.Read4_Configs()
--- 内部异常堆栈跟踪的结尾 ---
在 System.Xml.Serialization.XmlSerializer.Deserialize(XmlReader xmlReader, String encodingStyle, XmlDeserializationEvents events)
在 System.Xml.Serialization.XmlSerializer.Deserialize(Stream stream)
在 DetectSys.Configs.LoadConfig() 位置 E:\DefctFramework\code\submitDS\DetectSystem\DetectSys.BLL\Config.cs:行号 55

报错时,xml文件

查看了一下序列化的文件,在文件最后总是会多出一些垃圾字符导致反序列化错误
<?xml version="1.0"?>
<Configs xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<Settings>
<Setter Key="AppTitle" Value="三维可视化" />
<Setter Key="WeatherCityName" Value="达州" />
<Setter Key="UavFlyCenterPoint" Value="107.204756400529,31.1305284689069,160.0" />
<Setter Key="SqlDbString" Value="Server=127.0.0.1;uid=root;Password=root;Database=d3videofusion" />
<Setter Key="IGetWeatherImpl" Value="WeatherPlugins.Impl.LocalWheather,WeatherPlugins.dll" />
<Setter Key="autoBallonLayers" Value="tmpLayer\建筑信息.lgd;tmpLayer\建筑信息2.lgd" />
<Setter Key="GlaFile" Value="Gla\qingdao.gla" />
<Setter Key="GlaFile2" Value="Gla\shiyan2.gla" />
<Setter Key="region1" Value="tmpLayer\1片区.lgd;tmpLayer\pianqu.lgd" />
<Setter Key="region2" Value="tmpLayer\2pianqu.lgd" />
<Setter Key="region3" Value="tmpLayer\3pianqu.lgd" />
<Setter Key="region4" Value="tmpLayer\4pianqu.lgd" />
<Setter Key="region5" Value="tmpLayer\5pianqu.lgd" />
<Setter Key="region6" Value="tmpLayer\6pianqu.lgd" />
<Setter Key="region7" Value="tmpLayer\7pianqu.lgd" />
<Setter Key="region8" Value="tmpLayer\8pianqu.lgd" />
<Setter Key="region9" Value="tmpLayer\9pianqu.lgd" />
<Setter Key="region10" Value="tmpLayer\10pianqu.lgd" />
<Setter Key="region11" Value="tmpLayer\11pianqu.lgd" />
<Setter Key="region12" Value="tmpLayer\12pianqu.lgd" />
<Setter Key="LastSelectedDir" Value="E:\DefctFramework\数据\cout8" />
</Settings>
<Catalogs>
<Catalog Key="PATH_IMAGE_ICON_LABEL" Value="Resource\images\IconLabel" />
<Catalog Key="PATH_FengKongQu" Value="tmpLayer\封控区.lgd" />
<Catalog Key="PATH_HeXinQu" Value="tmpLayer\核心区.lgd" />
<Catalog Key="PATH_JingJieQu" Value="tmpLayer\警戒区.lgd" />
<Catalog Key="PATH_IMAGE" Value="resource\images" />
<Catalog Key="PATH_FRAME" Value="resource\frame" />
<Catalog Key="PATH_THREEDLL" Value="ThreeDll" />
<Catalog Key="PATH_JingJieQu" Value="tmpLayer\警戒区.lgd" />
<Catalog Key="PATH_IMAGE" Value="resource\images" />
<Catalog Key="PATH_FRAME" Value="resource\frame" />
<Catalog Key="PATH_THREEDLL" Value="ThreeDll" />
<Catalog Key="key" Value="value" />
</Catalogs>
</Configs>Configs>

报错的直接原因是xml文件后面多了

 Configs>
这种现象我称之为 拖尾现象
注意,多出的垃圾字符是不是随意的,是有规律的。

分析问题

但是为什么会多呢

先检查序列化代码。代码如下

public void Save()
{
if (config != null)
{
if (!File.Exists(saveFile))
{
File.Create(saveFile).Close();
}
XmlSerializer serializer = new XmlSerializer(typeof(Configs));
using (FileStream stream = new FileStream(saveFile, FileMode.Open))
{
serializer.Serialize(stream, config);
}
}
}

经过分析,问题就出在文件的打开方式上。

FileMode.Open方式,会覆盖原始文件。如果新的对象长度小于原始对象长度,就会出现拖尾现象。

解决问题

把FileStream打开方式改为Truncate,问题解决

public void Save()
{
if (config != null)
{
if (!File.Exists(saveFile))
{
File.Create(saveFile).Close();
}
XmlSerializer serializer = new XmlSerializer(typeof(Configs));
using (FileStream stream = new FileStream(saveFile, FileMode.Truncate))
{
serializer.Serialize(stream, config);
}
}
}

tag

记录一次错误处理 (xml序列化和反序列化相关)的更多相关文章

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

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

  2. XML 序列化与反序列化

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

随机推荐

  1. java 银联接口开发

    http://blog.sina.com.cn/s/blog_6c868c470100ys59.html 在线接口文档:http://wenku.baidu.com/link?url=EUgAuOKz ...

  2. c++11 初始化列表 bind function 示例

    // 111111111111.cpp: 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> #incl ...

  3. ubuntu下安装maven(转载)

    下载maven http://maven.apache.org/download.cgi 解压 tar -xzvf apache-maven-3.0.5-bin.tar.gz 配置环境变量 sudo ...

  4. 【Linux】 Ncures库的介绍与安装

    Ncures库的介绍 ncurses(new curses)是一套编程库,它提供了一系列的函数以便使用者调用它们去生成基于文本的用户界面. ncurses名字中的n意味着“new”,因为它是curse ...

  5. NOIP水题测试(2017082401)

    哈,水题测试又来了! 上次的水题简单吧! 答案是以单题形式发布的(旅行家的预算随后发布). 下面来看今天的题,还是水题. 时间限制:5小时 题目一:看上去就很水 题目二:比上面一题还水 题目三:数的划 ...

  6. 在 Anaconda下解决国内安装tensorflow等下载慢和中断,出错,异常问题的一点思路

    把镜像地址改为清华大学开源软件镜像站,打开 管理员身份打开cmd 输入conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/ ...

  7. 【转】python 修改os环境变量

    举一个很简单的例子,如果你发现一个包或者模块,明明是有的,但是会发生这样的错误: >>> from algorithm import *Traceback (most recent ...

  8. fmt标签如何计算两个日期之间相隔的天数

    <h2>start -- ${start}</h2><h2>end -- ${end}</h2><fmt:formatDate var=" ...

  9. Softmax && Cross-entropy Error

    softmax 函数,被称为 归一化指数函数,是sigmoid函数的推广. 它将向量等比压缩到[0, 1]之间,所有元素和为1. 图解: Example: softmax([1, 2, 3, 4, 1 ...

  10. mysql 数据插入优化方法(concurrent_insert=2)

    当一个线程对一个表执行一个DELAYED语句时,如果不存在这样的处理程序,一个处理器线程被创建以处理对于该表的所有DELAYED语句.通常来说,在MyISAM里读写操作是串行的,但当对同一个表进行查询 ...