用ASP.NET结合XML制作广告管理程序

  • 来源: 互联网 作者: rocket   2008-03-17/14:09
  • 本文介绍一下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>


    评论 {{userinfo.comments}}

    {{money}}

    {{question.question}}

    A {{question.A}}
    B {{question.B}}
    C {{question.C}}
    D {{question.D}}
    提交

    驱动号 更多