一、錯誤(以外)的處理程序健全性最基本要求就是程式錯誤的處理與捕捉,在ASP.NET中,錯誤的處理有和其他程式語言一樣的機制,可以使用Try…Catch…Finally等方式,這一點和ASP相比有較大的進步。而且,使用這些錯誤處理方法,可以大大提高程序的可讀性和程序調試速度,在這幾個優勢結合的情況下,我們更加應該注意這一點。
關於錯誤的處理,我們可以參考這篇文章(英文):
http://www.123aspx.com/redir.aspx?res=28336
二、 字串的處理網頁設計中,字串的處理幾乎是最常見的了。使用ASP.NET以後,字串的處理比ASP的速度快,而且,在ASP.NET中,專門增加一個字串處理類別StringBulider,使用這個類別可以完成一些常見的字串操作,而最主要的,使用StringBuilder可以大大提高字串處理速度。
在ASP.NET中,最常見的就是使用「&」來連接兩個字串:
Dim myOutputString As String = "My name is"
Dim myInputString As String = " Alex"
myOutputString = myOutputString & myInputString
Response.Write(myoutputString)
現在,我們來看看StringBuilder的使用,在使用StringBuilder的時候,我們對字串可以做一些基本的操作,比如Append、Replace、Insert、Remove等,現在我們來看具體舉例。
(1)StringBuilder中Append的使用
Append和其他語言的Append一樣,就是在字串最後增加其他字元。
Dim sb as StringBuilder = New StringBuilder()
sb.append( "<table border='1' width='80%'>" )
For i = 0 To RowCount - 1
sb.Append("<tr>")
For k = 0 To ColCount - 1
sb.Append("<td>")
sb.Append( dt.Rows(i).Item(k, DataRowVersion.Current).toString())
sb.Append( "</td>" )
Next
sb.Append("<tr>")
Next
sb.Append( "</table>")
Dim strOutput as String = sb.ToString()
lblCompany.Text = strOutput
在以上的程式中,用Append方法實作了一個表格的輸出,需要注意的一點是,StringBulider必須先使用ToString()方法將其轉換為String類型才可以直接輸出。在以上的舉例中,我們看到的全部是Append一個直接的字符串,其實,這個方法有一個很方便的功能,那就是可以直接Append其他類型的變量,比如可以直接Appemd一個Integer類型的數值,當然,我們輸出以後自動轉化為一個字串:
Sub Page_Load(Source As object, E As EventArgs)
Dim sb As System.Text.StringBuilder
Dim varother As Integer
varother=9999
sb =new System.Text.StringBuilder()
sb.append("<font color='blue'>可以Append其他型別:</font>")
sb.append(varother)
Response.write(sb.toString())
End Sub
(2)字串中其他方法的使用我們還可以使用其他方法,我們來看看常見的:
Insert方法,可以在指定位置插入其他字元,使用方法:Insert(插入位置,插入字元);
Remove方法,可以在指定位置刪除指定字數字符,使用方法:Remove(其實位置,字元數);
Replace方法,可以替換指定字元,使用方法:replace(被替換字串,替換字串)
字串的具體介紹和使用方法可以參考以下文章(英文):
http://aspfree.com/aspnet/stringbuilder.aspx
http://msdn.microsoft.com/library/en-us/cpref/html/frlrfSystemTextStringBuilderClassTopic.asp
三、 資料庫連結Connection和DataReader的關閉在使用ASP程式設計的時候,我們就已經知道,在使用資料庫連線以後,一定要將連線關閉,然後設定為NoThing。在Asp.NET中,我們仍然需要這樣使用,不過,在ASP.NET中,由於使用了ADO.NET,所以,在一些相關的處理方面,實際還是有一些細微的區別,而這些區別,往往也就是我們設計的時候最需要注意的。現在,我們透過舉例,來看看在常見的ADO.NET操作中,需要注意哪些問題。
(1)舉例一
Dim myConnection As SqlConnection = new SqlConnection(ConfigurationSettings.AppSettings("DSN_pubs"))
Dim myCommand As SqlCommand = new SqlCommand("Select pub_id, pub_name From publishers", myConnection)
Dim myDataReader As SqlDataReader
Try
myConnection.Open()
myDataReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection)
dropDownList1.DataSource = myDataReader
dropDownList1.DataBind()
Catch myException As Exception
Response.Write("An error has occurred: " & myException.ToString())
Finally
If Not myDataReader Is Nothing Then
'關閉DataReader
myDataReader.Close()
End If
End Try
在以上的舉例中,我們注意到,這裡只關閉了DataReader,並沒有關閉Connection。為什麼呢?仔細觀察以上的ExecuteReader方法,原來,設定了ExecuteReader參數,當執行完ExecuteReader以後,會自動關閉Connection。所以,這樣設定以後,就沒有必要再手動關閉Connection了。
(2)舉例二
Dim myConnection As SqlConnection = new SqlConnection(ConfigurationSettings.AppSettings("DSN_pubs"))
Dim myCommand As SqlCommand = new SqlCommand("Select pub_id, pub_name From publishers", myConnection)
Try
myConnection.Open()
dropDownList1.DataSource = myCommand.ExecuteReader()
dropDownList1.DataBind()
Catch myException As Exception
Response.Write("An error has occurred: " & myException.ToString())
Finally
If Not myConnection Is Nothing AndAlso ((myConnection.State And ConnectionState.Open) = ConnectionState.Open) Then
myConnection.Close()
End If
End Try
在以上的舉例中,我們發現,居然沒有關閉DataReader。為什麼呢?其實上面的程式碼中,沒有直接生成DataReader物件,當然也就無從關閉了。要注意一點的是,在關閉Connection之前,程序首先判斷Connection是否已經打開,如果沒有打開,也就沒必要關閉了。
四、使用Web.Config/Maching.Config保存常用資料一些資料我們需要時常使用,例如使用ADO.NET的時候,最常見的就是資料庫連結語句,在ASP,我們常常將這些資訊保存在Application中。當然,在ASP.NET中,也可以這樣,不過,ASP.NET已經提供一個設定檔WEB.Config,所以,我們最好將這些資訊保存在WEB.Config中,當然,我們也可以保存在Machine. Config中,不過,這樣的話,整個網站都必須使用,所以,一般我們都使用Web.Config。現在,我們來看具體這個文件的使用。
(1)Web.Config檔案的設定首先,我們來看Web.Config的設定,我們在這個檔案中增加設定以下兩個項目,設定如下:
<configuration>
<appsettings>
<add key="dsn" value="myserver"/>
<add key="someotherkey" value="somevalue"/>
</appsettings>
</configuration>
(2)變數的使用以上XML檔案設定了dsn和someotherkey兩個變數,現在我們看看程式中如何使用:
<html>
<script language="VB" runat=server>
Sub Page_Load(Sender as object, E as EventArgs)
Dim AppSettings as Hashtable = Context.GetConfig("appsettings")
DSN.Text = AppSettings("dsn")
SomeOther.Text = AppSettings("someotherkey")
End Sub
</script>
<body>
DSN Setting: <asp:label id="DSN" runat=server/> <br>
Some Other Setting: <asp:label id="SomeOther" runat=server/>
</body>
</html>
上面的程式我們看到,使用這樣定義的變數很簡單也很方便。
五、使用.NET的方式調試程序
ASP程式的調試一直是寫ASP最難的地方,這一點,ASP程式設計師大概都深有體會,因為大家都是用Response.write來調試。而這樣調試最大的缺點是,當我們調試完畢,必須一個個來刪除或者註釋掉這些信息,想一想,如果程序代碼達到幾百行或者頁面很多的程序,這樣的工作是多麼枯燥,最怕一點,忘記將這些調試用的write刪除,可能在用戶使用的時候就會出現一些不雅的調試信息。
使用ASP.NET以後,我們可以直接定義Trace來實現程式的調試。以上提到的麻煩可以輕鬆解決,熟悉,Trace可以通過具體頁面和在Web.Config配置文件中來定義實現,這樣,當程序調試完畢以後,直接將Trace設置為Off就可以了,這樣,程序就不會有調試功能了。
(1)頁面調試的實現在一個具體的頁面需要實現調試功能的時候,我們可以這樣設置:
<%@ Page Language="VB" Trace="True" %>
(2)定義WEB.Config實作在WEB.CONFIG中,我們也可以實現程式偵錯的開啟:
<configuration>
<system.web>
<trace enabled="true" requestLimit="10" localOnly="false"/>
</system.web>
</configuration>
使用以上的設定開啟Trace以後,我們在具體的程式中就可以使用Trace來調試程式了,比如:
Trace.Write("This is some custom debugging information")
或者調試程式變數:
Trace.Write("This is is my variable and it's value is:" & myVariable.ToString())
以上設定我們可以看出,在ASP.NET中,程式調試功能已經很方便簡單了