首页 > 编程 > .NET > 正文

asp.net类序列化生成xml文件实例详解

2024-07-10 13:29:41
字体:
来源:转载
供稿:网友

这篇文章主要介绍了asp.net类序列化生成xml文件的方法,结合实例形式较为详细的分析了asp.net序列化生成xml文件的具体步骤与相关实现技巧,需要的朋友可以参考下

本文实例讲述了asp.net类序列化生成xml文件的方法。分享给大家供大家参考,具体如下:

根据设计的需求需要开发多个商品的API 原XML文件如下:

 

 
  1. <urlset> 
  2. <url> 
  3. <loc>http://www.xxxxx.com/todaydetials.aspx?id=143</loc> 
  4. <data> 
  5. <display> 
  6. <website>爱购114</website> 
  7. <siteurl>http://www.xxxxx.com/</siteurl> 
  8. <city>杭州</city> 
  9. <webSitetitle></webSitetitle> 
  10. <image></image> 
  11. <startTime>2011-2-9</startTime> 
  12. <endTime>2011-2-15</endTime> 
  13. <value>3880</value> 
  14. <price>2088</price> 
  15. <rebate>0.53</rebate> 
  16. <bought>0</bought> 
  17. </display>  
  18. </data> 
  19. </url> 
  20. </urlset> 

现在需求是要根据数据库有几条商品信息 相应的API XML文件出现几个URL节点! 采用类序列化成XML文件然后读取相应生成的XML文件就可以展示多个商品XML的信息 实现代码如下:

首先定义好XML 各个节点的数据及父子节点的关系类:

 

 
  1. #region 定义数据实体类xml数据结构 
  2. public class urlset 
  3. public List<url> urlList 
  4. get; 
  5. set; 
  6. public class url 
  7. public string loc 
  8. get; 
  9. set; 
  10. public List<data> dataList 
  11. get; 
  12. set; 
  13. public class data 
  14. public List<display> displayList 
  15. get; 
  16. set; 
  17. public class display 
  18. public string website 
  19. get; 
  20. set; 
  21. public string siteurl 
  22. get; 
  23. set; 
  24. public string city 
  25. get; 
  26. set; 
  27. public string webSitetitle 
  28. get; 
  29. set; 
  30. public string image 
  31. get; 
  32. set; 
  33. public string startTime 
  34. get; 
  35. set; 
  36. public string endTime 
  37. get; 
  38. set; 
  39. public double value 
  40. get; 
  41. set; 
  42. public double price 
  43. get; 
  44. set; 
  45. public double rebate 
  46. get; 
  47. set; 
  48. public int bought 
  49. get; 
  50. set; 
  51. #endregion 

第二步:#region 定义获取网站信息实体类

 

 
  1. public class WebSiteInfo 
  2. /// <summary> 
  3. /// 商品标题 
  4. /// </summary> 
  5. public string title { get; set; } 
  6. /// <summary> 
  7. /// 商品发布时间 
  8. /// </summary> 
  9. public DateTime createtime { get; set; } 
  10. /// <summary> 
  11. /// 商品图片 
  12. /// </summary> 
  13. public string productimg { get; set; } 
  14. /// <summary> 
  15. /// 市场价 
  16. /// </summary> 
  17. public decimal market_price { get; set; } 
  18. /// <summary> 
  19. /// 团购价 
  20. /// </summary> 
  21. public decimal team_price { get; set; } 
  22. /// <summary> 
  23. /// 折扣价 
  24. /// </summary> 
  25. public decimal zhekou_price { get; set; } 
  26. /// <summary> 
  27. /// 城市名称  
  28. /// </summary> 
  29. public string cityName { get; set; } 
  30. /// <summary> 
  31. /// 商品开始时间 
  32. /// </summary> 
  33. public DateTime begin_time { get; set; } 
  34. /// <summary> 
  35. /// 结束时间 
  36. /// </summary> 
  37. public DateTime end_time { get; set; } 
  38. /// <summary> 
  39. /// 商家名称 
  40. /// </summary> 
  41. public string merchants_id { get; set; } 
  42. /// <summary> 
  43. /// 本单详情 
  44. /// </summary> 
  45. public string description { get; set; } 
  46. /// <summary> 
  47. /// 最低购买人数 
  48. /// </summary> 
  49. public int lowBuNo { get; set; } 
  50. /// <summary> 
  51. /// 商家地址 
  52. /// </summary> 
  53. public string Address { get; set; } 
  54. /// <summary> 
  55. /// 商家电话 
  56. /// </summary> 
  57. public string Telphone { get; set; } 
  58. /// <summary> 
  59. /// 城市区号 
  60. /// </summary> 
  61. public string cCode { get; set; } 
  62. /// <summary> 
  63. /// 文件夹名称 
  64. /// </summary> 
  65. public string folderName { get; set; } 
  66. /// <summary> 
  67. /// 团购状态  
  68. /// </summary> 
  69. public string StatusMessage { get; set; } 
  70. /// <summary> 
  71. /// 现在购买人数 
  72. /// </summary> 
  73. public int nownumber { get; set; } 
  74. /// <summary> 
  75. /// 商品编号 
  76. /// </summary> 
  77. public int productID { get; set; } 
  78. #endregion 

第三步:获取数据库商品信息记录并添加到对象的集合中(Arraylist):

 

 
  1. #region 获取xml实体类信息 
  2. /// <summary> 
  3. /// 获取xml实体类信息 
  4. /// </summary> 
  5. /// <returns></returns> 
  6. public static ArrayList GetWebModelInfo() 
  7. ArrayList list = new ArrayList(); 
  8. string strSQL = "select a.id, a.merchantsID,a.cCode,a.prodCode,a.statue,a.now_number, a.title,a.createtime,a.productimg,a.market_price,a.team_price,a.zhekou_price,a.cityName,a.begin_time,a.end_time,a.description,a.lowBuyNo,b.Address,b.Tel from tg_product as a left join tg_merchants as b on a.merchantsID=b.merchants_id where a.ispublic=1 and statue>-1 and getdate()<dateadd(day,1,a.end_time) order by a.createtime desc"
  9. DataSet ds = FrameWork.Data.SqlHelper.ReturnDataSet(CommandType.Text, strSQL, null); 
  10. if (ds.Tables[0].Rows.Count > 0) 
  11. foreach (DataRow dr in ds.Tables[0].Rows) 
  12. WebSiteInfo webModel = new WebSiteInfo(); 
  13. //城市名称 
  14. webModel.cityName = dr["cityName"].ToString(); 
  15. //商品标题 
  16. webModel.title = dr["title"].ToString(); 
  17. //商品创建时间 
  18. webModel.createtime = Convert.ToDateTime(dr["createtime"].ToString()); 
  19. //商家名称 
  20. webModel.merchants_id = dr["merchantsID"].ToString(); 
  21. //商品图片 
  22. webModel.productimg = dr["productimg"].ToString(); 
  23. //市场价 
  24. webModel.market_price = Convert.ToDecimal(dr["market_price"].ToString()); 
  25. //团购价 
  26. webModel.team_price = Convert.ToDecimal(dr["team_price"].ToString()); 
  27. //折扣价 
  28. webModel.zhekou_price = Convert.ToDecimal(dr["zhekou_price"].ToString()); 
  29. //开始时间 
  30. webModel.begin_time = Convert.ToDateTime(dr["begin_time"].ToString()); 
  31. //结束时间 
  32. webModel.end_time = Convert.ToDateTime(dr["end_time"].ToString()); 
  33. //商品说明 
  34. webModel.description = dr["description"].ToString(); 
  35. //最低购买数量 
  36. webModel.lowBuNo = Convert.ToInt32(dr["lowBuyNo"].ToString()); 
  37. //商家电话 
  38. webModel.Telphone = dr["Tel"].ToString(); 
  39. //商家地址 
  40. webModel.Address = dr["Address"].ToString(); 
  41. //城市编号 
  42. webModel.cCode = dr["cCode"].ToString(); 
  43. //图片文件夹名称 
  44. webModel.folderName = dr["prodCode"].ToString(); 
  45. //现在购买人数 
  46. webModel.nownumber = Convert.ToInt32(dr["now_number"].ToString()); 
  47. //商品编号 
  48. webModel.productID = Convert.ToInt32(dr["id"].ToString()); 
  49. int status = Convert.ToInt32(dr["statue"].ToString()); 
  50. switch (status) 
  51. case 0: 
  52. webModel.StatusMessage = "结束"
  53. break
  54. case 1: 
  55. webModel.StatusMessage = "成功"
  56. break
  57. list.Add(webModel); 
  58. return list; 
  59. #endregion 

最后一步将数据库读取来的信息赋值到XML 数据类型中 并序列化成XML文件保存成XML格式的文件读取文件展现到界面:

 

 
  1. #region 页面加载 根据数据库商品记录数生成xml文件信息 
  2. /// <summary> 
  3. /// 页面加载 根据数据库商品记录数生成xml文件信息 
  4. /// </summary> 
  5. List<url> urlList = null
  6. urlset urlsetList = new urlset(); 
  7. protected void Page_Load(object sender, EventArgs e) 
  8. if (!Page.IsPostBack) 
  9. ArrayList listinfo=GetWebModelInfo(); 
  10. urlList = new List<url>(); 
  11. for (int i = 0; i < listinfo.Count; i++) 
  12. WebSiteInfo webInfo = listinfo[i] as WebSiteInfo; 
  13. List<display> displayList = new List<display>(); 
  14. display display = new display(); 
  15. display.website = "爱购114"
  16. display.siteurl = "http://www.xxxxx.com/"
  17. //城市名称 
  18. display.city = webInfo.cityName; 
  19. //商品标题 
  20. display.webSitetitle = webInfo.title; 
  21. //商品图片 
  22. display.image = "http://211.155.235.30/tuangou/" + webInfo.folderName + "/" + webInfo.productimg; 
  23. //商品开始时间 
  24. display.startTime = webInfo.begin_time.ToShortDateString(); 
  25. //商品结束时间 
  26. display.endTime = webInfo.end_time.ToShortDateString(); 
  27. //市场价 
  28. display.value = Convert.ToDouble(webInfo.market_price); 
  29. //团购价 
  30. display.price = Convert.ToDouble(webInfo.team_price); 
  31. //折扣价 
  32. display.rebate = Convert.ToDouble(webInfo.zhekou_price); 
  33. //现在购买的人数 
  34. display.bought = webInfo.nownumber; 
  35. displayList.Add(display); 
  36. List<data> dataList = new List<data>(); 
  37. data data = new data(); 
  38. data.displayList = displayList; 
  39. dataList.Add(data); 
  40. url url = new url(); 
  41. url.loc = String.Format("http://www.xxxxx.com/todaydetials.aspx?id={0}", webInfo.productID.ToString()); 
  42. url.dataList = dataList; 
  43. urlList.Add(url); 
  44. urlsetList.urlList = urlList; 
  45. try 
  46. XmlSerializerNamespaces xmlns = new XmlSerializerNamespaces(); 
  47. xmlns.Add(String.Empty, String.Empty); 
  48. //构造字符串 
  49. StringBuilder sb = new StringBuilder(); 
  50. //将字符串写入到stringWriter对象中 
  51. StringWriter sw = new StringWriter(sb); 
  52. //xml序列化对象 typeof(类名) 
  53. XmlSerializer ser = new XmlSerializer(typeof(urlset)); 
  54. //把Stream对象和urlset一起传入,序列化出一个字符串sb 
  55. ser.Serialize(sw, urlsetList, xmlns); 
  56. sw.Close(); 
  57. string FILE_NAME = HttpContext.Current.Server.MapPath("API/54tuan.xml"); 
  58. FileInfo fi = new FileInfo(FILE_NAME); 
  59. //如果文件己经存在则删除该文件  
  60. if (fi.Exists) 
  61. if (fi.Attributes.ToString().IndexOf("ReadOnly") >= 0) { 
  62. fi.Attributes = FileAttributes.Normal; 
  63. File.Delete(fi.Name); 
  64. //创建文件 并写入字符串 
  65. using (StreamWriter sWrite = File.CreateText(FILE_NAME)) 
  66. sWrite.Write(sb.ToString().Replace("encoding=/"utf-16/"""encoding=/"utf-8/"").Replace("<urlList>""").Replace("</urlList>""").Replace("<dataList>""").Replace("</dataList>""").Replace("<displayList>""").Replace("<displayList>""").Replace("</displayList>""")); 
  67. sWrite.Close(); 
  68. //输出序列化后xml文件 
  69. Response.ClearContent(); 
  70. Response.ClearHeaders(); 
  71. Response.ContentType = "application/xml"
  72. Response.WriteFile(HttpContext.Current.Server.MapPath("API/54tuan.xml")); 
  73. Response.Flush(); 
  74. Response.Close(); 
  75. catch (Exception ex) 
  76. Response.Write(ex.Message); 
  77. finally 
  78. #endregion 

希望本文所述对大家asp.net程序设计有所帮助。


注:相关教程知识阅读请移步到ASP.NET教程频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表