一個WEBFORM——這裡將介紹ASP.NET WEBFORM的基本概念,以及其中表單項的變化。
*一個資料庫的應用——如何利用CONFIG.WEB中設置的DNS連接資料庫,資料庫操作對象的一些基本用法。
*EMAIL發送——在 引入一個系統類庫後(用IMPORT 標識符 ),利用msgMail對象,可以很方便的操作郵件發送過程。
*上傳——<INPUT TYPE=FILE …… 這樣一個INPUT 項在ASP.NET中有POSTEDFILE屬性,結合SAVEAS 事件,就可以實現上傳了。
一、 WEBFORM的使用
以下為引用的內容:<script language="C#" runat=server>
void SubmitBtn_Click(Object sender, EventArgs e) {
Message.Text = "Hi " + Name.Text + ", you selected: " + Category.SelectedItem;
}
</script>
以上是用C#寫的一個事件處理函數,void SubmitBtn_Click(Object sender , EventArgs e) , void代表該函數沒有返回值,sender是事件中觸發的對象,在這裡就是button對象,e是觸發事件的參數。該函數中的Message、Name、Category並沒有定義,它們來自下面的代碼:
以下為引用的內容:<form action="intro6.aspx" method="post" runat="server">
<h3> Name: <asp:textbox id="Name" runat="server"/>
Category: <asp:dropdownlist id="Category" runat=server>
<asp:listitem>psychology</asp:listitem>
<asp:listitem>business</asp:listitem>
<asp:listitem>popular_comp</asp:listitem>
</asp:dropdownlist>
<asp:button type=submit text="Lookup" OnClick="SubmitBtn_Click" runat="server"/>
<p>
<asp:label id="Message" runat="server"/>
</form>
首先可以注意到表單的寫法和html表單完全不同.所有的表單項包括表單本身後面都加上了runat=server,這一屬性說明這是伺服器端控制項,原先的文本輸入,下拉菜單等的寫法也變了。在這裡採用的是:
<asp:<控制項類別> id=[ID] 屬性= runat="server"/>
控制項的種類有很多(所有控制項的列表可以附錄中找到),各個控制項的屬性當然不一樣,這會在今後詳細介紹,上面的代碼中,我們可以看見的有textbox、button的id、text屬性,以及dropdownlist的SelectedItem屬性(注意:這個屬性只針對C#,在VB中,要用SelectedItem.Text屬性來作為相應的代替)。
這裡出現了一個伺服器端控制<asp:label id=」Message」 runat=」server」/>,這個asp:label是傳統表單所沒有的,它是一個伺服器端文本控制,那麼就存在一個問題,如果傳統的HTML裡沒有這個元素,那麼ASP+是怎麼接收的呢?你運行一下這個程序,然後看一下HTML源碼,你會發現這麼一行:
<INPUT type="hidden" name="__VIEWSTATE" value="a0z-1715863018__x">
對,ASP+就是通過這個隱藏表單的形式傳遞過去的。另外,在提交後你可以發現在文本框中填寫的內容,以及下拉菜單的選擇都被保留下來了,這在ASP中需要代碼來實現。
需要提出的一點,在ASP.NET中,還可以有另一種方式添加伺服器端控制項:
以下為引用的內容:<script language="C#" runat=server>
void AddText(){
TextBox text1=new TextBox();
text1.Text="TEST";
……
}
</script>
這一段代碼添加了一個TextBox控制項。更多內容,可參看: 什麼是ASP.NET的WEBFORM
二、一個資料庫連接的例子
使用DNS連接,代碼,說明
CONFIG.WEB 中的設置:
以下為引用的內容:<appsettings>
<add key="MyConn" value="server=localhost;uid=sa;pwd=mypassword;
Database=somedatabase"/>
</appsettings>
**********************************************************
<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.SQL" %>
<script language="VB" runat="server">
Sub Page_Load(Src As Object, E As EventArgs)
Dim MyConnection As SQLConnection
『SQLSERVER 的連接對象
Dim Config as HashTable
』定義一個本地變量
Config = Context.GetConfig("appsettings")
』用本地變量來保存DSN連接字符串變量
MyConnection = New SQLConnection(Config("MyConn"))
『建立連接
Dim MyCommand As SQLCommand
』申明一個Command對象來往database中插入數據
dim parm1 as string = "SomeTextValue"
dim parm1 as string = "SomeTextValue2"
Dim InsertCmd As String = "Insert into tablename values (@parm1, @parm2)"
'Using the connection string
'使用連接字符串
MyCommand = New SQLCommand(InsertCmd, MyConnection)
MyCommand.Parameters.Add(New SQLParameter("@Parm1", SQLDataType.VarChar, 50))
MyCommand.Parameters("@Parm1").Value = Parm1
MyCommand.Parameters.Add(New SQLParameter("@Parm2", SQLDataType.VarChar, 50))
MyCommand.Parameters("@Parm2").Value = Parm2
MyCommand.ActiveConnection.Open()
MyCommand.Execute()
MyCommand.ActiveConnection.Close()
End Sub
</script>
在以上的代碼中,在利用CONFIG.WEB中設置的DNS建立連接後,又用一個COMMAND 的對象完成了插入數據的操作.和從前的ADO沒什麼不同,只是對象名字有些改變。
三、一個發送郵件的例子
下面給出一段代碼,非常容易的實現了發送一封HTML格式,帶有附件的EMAIL。而不象ASP中需要自己編寫組件來實現。
以下為引用的內容:<% @Page Language="C#" %>
<% @Import Namespace="System.Web.Util" %>
<%
MailMessage msgMail = new MailMessage();
msgMail.To = "mail@mail.com";
msgMail.Cc = "mail1@mail.com";
msgMail.From = "webmaster@mail.com";
msgMail.Subject = "Attachment ";
msgMail.BodyFormat = MailFormat.Html;
string strBody = "<b>here is an attachment</b>";
msgMail.Body = strBody;
msgMail.Attachments.Add(new MailAttachment("c:\\temp\\test.txt"));
SmtpMail.Send(msgMail);
Response.Write("Email 已經發送成功");
%>
上面的代碼中,首先是引入System.Web.Util類庫,這樣才能調用MailMessage對象,有關它的屬性的使用,上面的代碼中已經很清楚了,要注意的地方有BodyFormat屬性在為MailFormat.Html時,郵件正文是HTML格式,如果改為MailFormat.Text,則是文本格式,還有,請檢查你的SMTP服務的設置,郵件發送需要它的支持。
四、一個上傳的例子
ASP中上傳文件需要自己寫組件,代碼,說明
以下為引用的內容:<html>
<script language="VB" runat=server>
Sub UploadBtn_Click(Sender as Object, E as EventArgs)
UploadFile.PostedFile.SaveAs(Server.MapPath("test.jpg"))
MyImage.ImageUrl = "test.jpg"
MyImage.Visible = true
End Sub
</script>
<body>
<form enctype="multipart/form-data" runat=server>
<h3>
Select File To Upload: <input id="UploadFile" type=file runat=server>
<asp:button Text="Upload Me!" OnClick="UploadBtn_Click" runat=server/>
<hr>
<asp:image id="MyImage" Visible=false runat=server/>
</form>
</body>
</html>
直接調用UploadFile對象(它所在的類庫是ASP.NET默認的,所以不用額外的 Import 一個 Namespace。)很容易的實現了上傳,不用象在ASP中那樣,要自己編寫上傳組件了。