用ASP.NET結合XML制作廣告管理程序
本文介紹一下ASP.Net中對XML的用法,這里飛刀我只是展現了XML與DataSet相結合的用法。其實ASP.Net對XML的操作的方法與對象是很多的,比如XmlDataDocument,XmlTextReader等,這些對象功能很全,也很實用。
本文以Adrotator控件使用的XML為例(新手可以先看一下Adrotator控件的用法),寫出了一個廣告管理程序。這個程序,飛刀用到的控件主要是DataGrid,可以說已經用到了DataGrid幾乎全部功能,大家在關注XML的同時,可以同時學到DataGrid使用方法。
先將本例中使用的一些方法對大家說明一下:
DataSet主要是使用的ReadXml與WriteXml方法。它們的功能看名字就知道了,飛刀也不羅嗦了。
DataGrid中使用的了很多的方法和對象。比如分頁使用AllowPaging屬性,排序使用AllowSorting屬性,本例中使用了所有DataGrid中的事件,比如OnItemCommand,OnEditCommand,OnCancelCommand,OnUpdateCommand等。
大家認真查看這些事件的處理。
另外大家在看程序時,再想想,如果這個程序使用ASP來寫需要多少頁,呵呵,用ASP.Net只需要一頁,而且無限次使用,這就是ASP.Net的優點。
程序中飛刀我做了些簡單的注釋,最重要的還是大家的理解。呵呵,最近我們工作室的人是忙得一踏糊涂,所以就請大家原諒啦。飛刀這些日子不是不寫程序,只是寫的程序都需要發表在書上,(比如和追捕軟件一樣功能的Web網頁啦,真的可以實現與追捕一樣的功能,絕無虛假)不能貼在網上啦。這樣會被罵的:)
先看看我們操作的XML文件的內容:
<?xml version="1.0" standalone="yes"?> <Advertisements> <xsd:schema id="Advertisements" targetNamespace="" xmlns="" xmlns:xsd="http://www.w3.org/1999/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"> <xsd:element name="Ad"> <xsd:complexType content="elementOnly"> <xsd:all> <xsd:element name="ImageUrl" minOccurs="0" type="xsd:string"/> <xsd:element name="NavigateUrl" minOccurs="0" type="xsd:string"/> <xsd:element name="AlternateText" minOccurs="0" type="xsd:string"/> <xsd:element name="Keyword" minOccurs="0" type="xsd:string"/> <xsd:element name="Impressions" minOccurs="0" type="xsd:string"/> </xsd:all> </xsd:complexType> </xsd:element> <xsd:element name="Advertisements" msdata:IsDataSet="True"> <xsd:complexType> <xsd:choice maxOccurs="unbounded"> <xsd:element ref="Ad"/> </xsd:choice> </xsd:complexType> </xsd:element> </xsd:schema> <Ad> <ImageUrl>aspcn_bbs1.gifc</ImageUrl> <NavigateUrl>http://www.aspcn.com/bbs</NavigateUrl> <AlternateText>ASPCN技術論壇/AlternateText> <Keyword>bbs</Keyword> <Impressions>50</Impressions> </Ad> <Ad> <ImageUrl>aspcn_bbs3.gif</ImageUrl> <NavigateUrl>http://www.aspcn.com/bbs</NavigateUrl> <AlternateText>ASPCN技術論壇/AlternateText> <Keyword>bbs</Keyword> <Impressions>50</Impressions> </Ad> <Ad> <ImageUrl>aspcn_bbs2.gifc</ImageUrl> <NavigateUrl>http://www.aspcn.com/bbs</NavigateUrl> <AlternateText>ASPCN技術論壇/AlternateText> <Keyword>bbs2</Keyword> <Impressions>50</Impressions> </Ad> <Ad> <ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl> <NavigateUrl>http://www.aspcn.com</NavigateUrl> <AlternateText>我是中國人/AlternateText> <Keyword>中國人/Keyword> <Impressions>80</Impressions> </Ad> <Ad> <ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl> <NavigateUrl>http://www.aspcn.com</NavigateUrl> <AlternateText>我是中國人/AlternateText> <Keyword>中國人/Keyword> <Impressions>80</Impressions> </Ad> <Ad> <ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl> <NavigateUrl>http://www.aspcn.com</NavigateUrl> <AlternateText>我是中國人/AlternateText> <Keyword>中國人/Keyword> <Impressions>80</Impressions> </Ad> <Ad> <ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl> <NavigateUrl>http://www.aspcn.com</NavigateUrl> <AlternateText>我是中國人/AlternateText> <Keyword>中國人/Keyword> <Impressions>80</Impressions> </Ad> <Ad> <ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl> <NavigateUrl>http://www.aspcn.com</NavigateUrl> <AlternateText>我是中國人/AlternateText> <Keyword>中國人/Keyword> <Impressions>80</Impressions> </Ad> <Ad> <ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl> <NavigateUrl>http://www.aspcn.com</NavigateUrl> <AlternateText>我是中國人/AlternateText> <Keyword>中國人/Keyword> <Impressions>80</Impressions> </Ad> <Ad> <ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl> <NavigateUrl>http://www.aspcn.com</NavigateUrl> <AlternateText>我是中國人/AlternateText> <Keyword>中國人/Keyword> <Impressions>80</Impressions> </Ad> <Ad> <ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl> <NavigateUrl>http://www.aspcn.com</NavigateUrl> <AlternateText>我是中國人/AlternateText> <Keyword>中國人/Keyword> <Impressions>80</Impressions> </Ad> <Ad> <ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl> <NavigateUrl>http://www.aspcn.com</NavigateUrl> <AlternateText>我是中國人/AlternateText> <Keyword>中國人/Keyword> <Impressions>80</Impressions> </Ad> <Ad> <ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl> <NavigateUrl>http://www.aspcn.com</NavigateUrl> <AlternateText>aaaddd</AlternateText> <Keyword>aaadd</Keyword> <Impressions>98090</Impressions> </Ad> <Ad> <ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl> <NavigateUrl></NavigateUrl> <AlternateText>aaasdfasfad</AlternateText> <Keyword>aaadd</Keyword> <Impressions>98090</Impressions> </Ad> <Ad> <ImageUrl>http://wwwaspcn.com</ImageUrl> <NavigateUrl>http://</NavigateUrl> <AlternateText></AlternateText> <Keyword></Keyword> <Impressions></Impressions> </Ad> </Advertisements> |
中文有點問題,但是在下面的程序中可以正常顯示的,因為用了國際化技術,哈哈,這個例子用的東東可不少喲:
這是Adrotator控件引用的標準格式XML。
我們再來看看ASP.Net的源代碼:
由于XML文件占了很大的篇幅,只好把源程序貼在這一頁了。(也是很長的喲,大家有性子看才行)
<% @ Page Language="C#" ResponseEncoding="gb2312" %> <% @ Import Namespace="System.Data" %> <% @ Import Namespace="System.Xml" %> <% @ Import Namespace="System.IO" %> <Script Language="C#" Runat="Server"> DataSet ds; file://定義公用的DataSet DataView dv; file://定義公用的DataView string SortField; string sPath; public void Page_Load(Object src,EventArgs e) { if(State["adxml"]==null) { sPath = Server.MapPath(".") + "\AdBanners\ad_gb.xml"; ds = new DataSet(); ds.ReadXml(sPath); State["adxml"] = ds; } else { ds = (DataSet)State["adxml"]; } dv = ds.Tables[0].DefaultView; dv.Sort = "ImageUrl"; if(!Page.IsPostBack) { CreateTable(); } } file://捆綁Binder public void CreateTable() { dgXML.DataSource = dv; dgXML.DataBind(); } file://翻頁時 public void dgXML_Changed(Object sender,DataGridPageChangedEventArgs e) { CreateTable(); } file://刪除 public void DelItem(Object sender,DataGridCommandEventArgs e) { if(((LinkButton)e.CommandSource).CommandName == "del") { file://首先取得當前更新頁的行數與CurrentPageIndex int CPI = (int)dgXML.CurrentPageIndex; int EII = (int)e.Item.ItemIndex; int row = CPI*5+EII; lb.Text = row.ToString(); file://刪除 dv.Delete(row); dgXML.EditItemIndex = -1; ds.WriteXml(sPath); CreateTable(); } } file://取消 public void dgXML_Cancel(Object sender,DataGridCommandEventArgs e) { dgXML.EditItemIndex = -1; CreateTable(); } file://編輯 public void dgXML_Edit(Object sender,DataGridCommandEventArgs e) { dgXML.EditItemIndex = (int)e.Item.ItemIndex; CreateTable(); } file://更新 public void dgXML_Update(Object sender, DataGridCommandEventArgs e) { try { file://首先取得當前更新頁的行數與CurrentPageIndex int CPI = (int)dgXML.CurrentPageIndex; int EII = (int)e.Item.ItemIndex; int row = CPI*5+EII; file://lb.Text = row.ToString(); file://取得各項值 string ImageUrl = ((TextBox)e.Item.Cells[2].Controls[0]).Text; string NavigateUrl = ((TextBox)e.Item.Cells[3].Controls[0]).Text; string AlternateText = ((TextBox)e.Item.Cells[4].Controls[0]).Text; string Keyword = ((TextBox)e.Item.Cells[5].Controls[0]).Text; string Impressions = ((TextBox)e.Item.Cells[6].Controls[0]).Text; dv.Delete(row); DataRow dr = ds.Tables[0].NewRow(); dr[0] = ImageUrl; dr[1] = NavigateUrl; dr[2] = AlternateText; dr[3] = Keyword; dr[4] = Impressions; ds.Tables[0].Rows.Add(dr); ds.WriteXml(sPath); } catch(Exception ee) { lb.Text = ee.ToString(); } dgXML.EditItemIndex = -1; CreateTable(); } public void PanelShow(Object sender,EventArgs e) { AddItem.Visible = true; } public void AddItem_Click(Object sender,EventArgs e) { DataRow dr = ds.Tables[0].NewRow(); dr[0] = mUrl.Text; dr[1] = aUrl.Text; dr[2] = mText.Text; dr[3] = aKey.Text; dr[4] = aTime.Text; ds.Tables[0].Rows.Add(dr); ds.WriteXml(sPath); CreateTable(); AddItem.Visible=false; } </script> <html> <head> <title></title> </head> <body> <form id="form1" runat="server"> <asp:DataGrid id="dgXML" runat="server" AllowPaging="True" PageSize="10" BorderColor="black" BorderWidth="1" CellPadding="3" Font-Name="Verdana" Font-Size="8pt" HeaderStyle-BackColor="#aaaadd" PagerStyle-Mode="NumericPages" PagerStyle-HorizontalAlign="Right" PagerStyle-PrevPageText="前頁" PagerStyle-NextPageText="后頁" OnPageIndexChanged="dgXML_Changed" OnEditCommand="dgXML_Edit" OnCancelCommand="dgXML_Cancel" OnUpdateCommand="dgXML_Update" OnItemCommand="DelItem" AutoGenerateColumns="false" > <property name="Columns"> <asp:ButtonColumn HeaderText="刪除" Text="刪除" CommandName="del" /> <asp:EditCommandColumn EditText="修改" CancelText="取消" UpdateText="更新" ItemStyle-Wrap="false" HeaderText="操作區" HeaderStyle-Wrap="false" /> <asp:BoundColumn HeaderText="圖片地址(相對)" SortField="ImageUrl" DataField="ImageUrl" /> <asp:BoundColumn HeaderText="鏈接URL" SortField="NavigateUrl" DataField="NavigateUrl" /> <asp:BoundColumn HeaderText="圖片說明" SortField="AlternateText" DataField="AlternateText" /> <asp:BoundColumn HeaderText="類別" SortField="Keyword" DataField="Keyword" /> <asp:BoundColumn HeaderText="顯示時間" SortField="Impressions" DataField="Impressions" /> </property> </asp:DataGrid> <hr> <asp:Button id="vi" Text="添加新項" OnClick="PanelShow" runat="server"/> <br> <asp:Panel id="AddItem" runat="server" Visible="false"> <table> <tr Bgcolor="#aaaadd"><td colspan=2>添加新的廣告頁面</td></tr> <tr> <td>廣告圖片URL:</td> <td><asp:TextBox id="mUrl" runat="server" Text="http://" /></td> </tr> <tr> <td>廣告鏈接地址:</td> <td><asp:TextBox id="aUrl" runat="server" Text="http://" /></td> </tr> <tr> <td>圖片說明:</td> <td><asp:TextBox id="mText" runat="server" /></td> </tr> <tr> <td>廣告所屬類別:</td> <td><asp:TextBox id="aKey" runat="server" /></td> </tr> <tr> <td>顯示時間</td> <td><asp:TextBox id="aTime" runat="server" /></td> </tr> <tr><td> <asp:Button id="submit" Text="提交" OnClick="AddItem_Click" runat="server" /></td></tr> </table> </asp:Panel> <asp:Label id="lb" runat="server" /> </form> </body> </html> |
大家好好分析吧。