程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> 通過序列化和反序列化泛型數據實體集合來實現持久化數據對象的方法

通過序列化和反序列化泛型數據實體集合來實現持久化數據對象的方法

編輯:.NET實例教程

通過序列化和反序列化泛型數據實體集合來實現持久化數據對象的方法

我們在平時使用數據庫的時候,經常會碰到一個問題,就是不希望數據實體對象插入數據庫中, 卻有想持久化的時候,那麼就可以用序列化成

XML字符串,來保存到其他地方,由於生成的是字符串,所以可以保存到任意我們想保存的地方。比如 ASP.Net的ViewState,cookIE,cache等。

首先,我們定義一個數據實體類。

 

    class Entity
    {
        public Entity()
        {}
        private int id;
        public int Id
        {
            get
            {
                return id;
            }
            set
            {
                id = value;
            }
        }
        private string name;
        public string Name
        {
            get
            {
                return name;
            }
            set
            {
                name = value;
            }
        }

        private double price;
        public double Price
        {
            get
            {
                return price;
            }
            set
            {
                price = value;
            }
        }
    }


於是將他插入到List<Entity>對象中

    List<Entity> list = new List<Entity>();
    Entity obj = new Entity();
    obj.Id = 1;
    obj.Name = "test";
    obj.Price = 3.23;
    list.Add(obj);
 這樣,一個List<Entity>對象就創建成功了,下面我們來將他序列化

        public static string Serialize<BusinessObject>(List<BusinessObject> GenericList)
        {
            XmlDocument result = new XMLDocument();
            result.LoadXML("<Root></Root>");
            foreach (BusinessObject obj in GenericList)
            {
                XMLElement Item = result.CreateElement("Item");
                PropertyInfo[] properties = obj.GetType().GetPropertIEs();
                foreach (PropertyInfo property in propertIEs)
                {
                    if (property.GetValue(obj, null) != null)
                    {
                        XMLElement element = result.CreateElement(property.Name);
                        element.SetAttribute("Type", property.PropertyType.Name);
                        element.InnerText = property.GetValue(obj, null).ToString();
                        Item.AppendChild(element);
                    }
                }
                result.DocumentElement.AppendChild(Item);
   &nbsp;        }
            return result.InnerXML;
        }
 然後我們調用這個方法

string str = Serialize<Entity>(list);
 生成的XML文件為:

    <Root>
        <Item>
            <Id Type="Int32">1</Id>
            <Name Type="String">test</Name>
            <Price Type="Double">3.23</Price>
        </Item>
    </Root>
下面,我們根據上面生成的XML文件,將他反序列化,生成剛才的List<Entity>對象

        public static List<BusinessObject> Deserialize<BusinessObject>(string XMLStr)
        {
            List<BusinessObject> result = new List<BusinessObject>();
            XmlDocument XmlDoc = new XMLDocument();
            XmlDoc.LoadXml(XMLStr);
            foreach (XmlNode ItemNode in XMLDoc.GetElementsByTagName("Root").Item(0).ChildNodes)
            {
                BusinessObject item = Activator.CreateInstance<BusinessObject>();
                PropertyInfo[] properties = typeof(BusinessObject).GetPropertIEs();
                foreach (XMLNode propertyNode in ItemNode.ChildNodes)
                {
                    string name = propertyNode.Name;
                    string type = propertyNode.Attributes["Type"].Value;
                    string value = propertyNode.InnerXML;
                    foreach (PropertyInfo property in propertIEs)
                    {
      

         if (name == property.Name)
                        {
                            property.SetValue(item,Convert.ChangeType(value,property.PropertyType), null);
                        }
                    }
                }
                result.Add(item);
            }
            return result;
        }
 然後我們調用這個方法:

List<Entity> list = Deserialize<Entity>(str);
 完了。

本文只是給大家介紹了序列化List<>對象的簡單方法,用的時候要根據自己的情況而定。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved