C#序列化对象转为为XML格式字符串

实习公司原来的左侧菜单是通过js进行ajax请求一个xml文件得到一个xml对象,然后拼接html文件,现在需要从数据库取数据生成xml,因为保密关系,太详细的不能放出来,简单说下流程

1、C#后台执行SQL,得到DataTable对象

2、变量DataTable对象,生成一个Dictionary,key就是主菜单,value就是这个主菜单包含的所有子菜单,是个ArrayList

3、变量这个Dictionary,根据每个key生成一个对象,这个对象的属性是个List,List中包含的是子菜单的对象

4、序列化这些对象,生成xml,转为字符串传给aspx

出于保密需要,我把问题抽象一下,这个xml可以用国家-省-城市来表达

从数据库取出的数据差不多长这样(这是多表join后的结果集):

id province city address
1 江苏 南京 nanjing
2 浙江 杭州 hangzhou
3 浙江 宁波 ningbo

最后需要生成的xml长这样:



  
    
  
  
    
    
  
  

首先,定义类

using System;
using System.Data;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.IO;
using System.Web.UI;
using System.Web.UI.WebControls;
using IAUOperation.db;
using System.Collections;
using System.Data.SqlClient;
using Operation.Web;
using System.Text;
using System.Xml;
using System.Xml.Serialization;

[XmlRoot("country")]
public class Country
{
    [XmlAttribute]
    public string width;

    [XmlElement("province")]
    public List provinces;

}


[XmlRoot("province")]
public class Province
{
    [XmlAttribute]
    public string name;

    [XmlElement("city")]
    public List cities;

}


public class City
{
    [XmlAttribute]
    public string name;

    [XmlAttribute]
    public string address;
}


public class CityItem
{
    public string province;

    public string city;

    public string address;
}

注意,这里保存主菜单和子菜单的对应关系时,不能用Hashtable,因为Hashtable是无序存储的,而菜单是必须有顺序的 

这里只给出了核心代码作为示例

DataTable dt = dbBase.executeInternalQuery(strSQL);

HashSet hashSetMenus = new HashSet();


Dictionary provinceCity = new Dictionary();

List CityItemList = new List();

for (int i = 0; i < dt.Rows.Count; i++)
{
    string tmpProvince = dt.Rows[i]["province"].ToString();
    hashSetProvinces.Add(tmpProvince);

    CityItem cityItem = new SubMenuItem();
    cityItem.province = tmpProvince;
    cityItem.city = dt.Rows[i]["city"].ToString();
    cityItem.address = dt.Rows[i]["address"].ToString();
    CityItemList.Add(cityItem);
}

for (int i = 0; i < dt.Rows.Count; i++)
{

    // 省
    string tmpProvince = dt.Rows[i]["province"].ToString();
    // 市
    string tmpCity = dt.Rows[i]["city"].ToString();

    if (hashSetProvinces.Contains(tmpMainMenu))
    {
        if (!provinceCity.ContainsKey(tmpMainMenu))
        {
            ArrayList citylist = new ArrayList();
            citylist.Add(tmpSubMenu);
            provinceCity.Add(tmpProvince, citylist);
        }
        else
        {
            ArrayList temp = provinceCity[tmpProvince] as ArrayList;
            temp.Add(tmpCity);

        }
    }

}

 

你可能感兴趣的:(C#,ASP.NET,xml,C#项目源码,Asp.net)