當前位置:開發者網絡 >> 技術教程 >> ASP教程 >> ASP應用 >> 內容
精彩推薦
分類最新教程
分類熱點教程
    
從ASP遷移至ASP+
作者:未知
日期:2004-08-25
人氣:
投稿:xiaxia(轉貼)
來源:未知
字體:
收藏:加入瀏覽器收藏
以下正文:
原作者: 雨晨
最初的考慮(一)

它包括運行平台的配置,pagelet的建立,新的ADO+的使用,如何使用新的DataSet進行數據訪問,HTML表格到DataList的轉變,以及其他多種新的服務器端控件的使用技巧……還等什麼?現在就來感受一下ASP+的全新魅力吧!)

   自從微軟在2000年7月的專業開發人員會議上宣佈了ASP+以來, 一個相同的問題一直困擾著許多新聞組及討論論壇:「我需要怎樣做以使現有的web應用程序從ASP轉換成asp+?」 專業開發人員會議的發言人稱:代碼方面無須作較大改動,整個轉換過程也並不太難。真是這樣嗎?在本文中,我們將一探究竟。

   要運行ASP+的alpha版本,你需要:

   Windows 2000 Professional server, 或者Advanced Server

   IIS5.0

   Internet Explorer5.5

   ..Net框架運行時(.Net Framwork Runtime)

   (未來發行的ASP+將可以在windows NT及9x上運行)

   如果你是一位ASP開發者,你當前使用的技巧如VBScript將輕鬆轉換到Visual Basic .Net來為你的ASP+頁面

   編寫代碼。你也可能使用其他的語言如:C#,Managed C++甚至Cobol。 在本文中,我會介紹將一個小型web應用程序從ASP升級到ASP+所需的詳細步驟。示例代碼使用Visual Basic .Net。

   儘管ASP與ASP+可以彼此交互共存,我們還是選擇將整個站點遷移至ASP+。被遷移的是一個示例站點,該站點被用來演示入門級的web開發 。我們覺得該站點代表了當前互聯網上相當一部分典型的中,小型站點。該站點網址是: http://www.codejunkies.net/eVille/, 它是一個虛擬招生網站, 招收的學生們將學習IT相關課程。該站點架設於Windows2000 Server上,由Access2000數據庫驅動,使用VBScript, 客戶端JavaScript以及ASP3.0,沒有使用COM。

   在同一台運行IIS5.0的WEB服務器上,ASP與ASP+被設計成為支持並行運行(最終發行版本將支持IIS其它版本)。這意味著我們可以一次一頁地來遷移整個站點。最初的頁面仍然可以在ASP3.0下繼續運行,而新的頁面將被轉換成為使用ASP+服務器控件與函數。

   我們要做的第一步就是要使IIS能夠將default.aspx作為一個有效的缺省文件。這一步相當簡單,在Internet Service Manager中:

   * 打開IIS虛擬目錄中的『屬性』對話框

   * 點擊『文件』標籤中的『添加』按鈕

   * 輸入Default.aspx

   * 點擊『確定』兩次

   做示例用的eVille站點沒有使用COM,因此所有的數據訪問都是通過ASP或者include文件中的ADO來完成的。我們初始的目標之一就是要將ADO轉換成ADO+以獲得由ADO+ Managed Provider帶來的更好執行效果。ASP+支持傳統ADO的使用,然而遷移到ADO+將受益更多。比方說:從單個DataSet中獲取多個表(table),更快的執行速度,將數據綁定到服務器控件。ASP+頁面中的數據訪問可以通過ADO,ADO+或是SQL Managed Provider來完成。由於示例站點沒有使用SQL Server,而我們又想對執行進行優化,所以ADO+成了我們最好的選擇。

   本站的每個頁面都涉及到數據訪問,所以它將在轉換工程中占最大的比例。基本上,每一頁都必須作一些代碼修改以獲取並顯示該頁所需的數據。在eVille的結構中有一個connect.inc文件,該文件包含ADO連接代碼,並且每個頁面中都有該文件。連接已經建好並且可以使用了。由於在ASP+中,連接到數據庫和綁定到ASP+數據控件的過程由新的Page_Load事件來完成,現在我們得採取一種稍微不同的方法。


最初的考慮(二)


   運用和在一個單獨模塊中創建一個普遍性的連接相同的構想,我們創建了一個Pagelet。Pagelet使開發人員可以創建偽控件,偽控件和對像一樣可以用來顯示屬性,方法以及事件。我們的方案是:創建一個顯示ConnectToDB方法的Pagelet,該方法返回一個ADOConnection對像(與ADO的語法稍有不同)。我們用下面的代碼創建Pagelet,將它存為connect.aspc(擴展名表明它是一個Pagelet)

   < %@ Import Namespace="System.Data" %>

   < %@ Import Namespace="System.Data.ADO" %>

   < script language="VB" runat="server">

   Public Function ConnectToDB() As ADOConnection

   ConnectToDB = New ADOConnection("DSN=evilleDSN")

   End Function

   < /script>

   你會注意到我們導入了兩個Namespaces,即System.Data和System.Data.ADO。為了使用ADO+ Managed Provider這些Namespaces是必須的。許多人就此問了我許多問題,因為目前多數示例都使用基於Microsoft SQL Server 2000數據庫的SQL Managed Provider。對於非SQL Server 數據庫,ASP+可以使用ADO+ Managed Provider,這和目前你在程序中使用ADO的方式大致相同。導入Namespaces和在VB程序中創建參考(Reference)有異曲同工之妙。

   Pagelet的運用使我可以維護當前的站點計劃,一旦在模塊中創建了連接,我們就可在任何需要的地方重用模塊。這意味著我們需要用Pagelet的一個實例來替代Include文件指令,然後當我們需要數據庫連接時調用ConnectToDB方法。在需要使用Pagelet的頁面中,我們首先必須使用ASP+指令將之與該頁面註冊(register)。在指令中,我們定義TagPrefix,TagName,以及Source(src)。與ASP中的include文件類似,在我們放置Pagelet的地方要用到TagPrefix和TagName。

   < %@ Register TagPrefix="seven" TagName="Connect"

   src="_includes/connect.aspc" %>

   放置我們剛註冊的Pagelet的方法與ASP+服務器控件類似:

   < [TagPrefix]:[TagName] id=myPagelet runat=server />

   比如:

   < seven:Connect id=Connect runat=server />

   在ADO+中,記錄集(Recordset)的概念被DataSets和DataViews的組合所取代。一會兒我們將討論這兩個概念。首先讓我們看看在default.asp頁面遷移至default.aspx(ASP+頁面的後綴)後代碼都有了哪些改變。先看default.asp:

   < !-- #include file="_includes/connect.inc" -->

   < %

   Dim cnEville_DB, rsUpcoming, strSqlUpcoming

   Set rsUpcoming = Server.CreateObject("ADODB.Recordset")

   strSqlUpcoming = " SELECT TOP 2 " & _

   "Classes.Title, Sessions.Session_ID, " & _

   "Sessions.Special, Classes.Description " & _

   "FROM Classes INNER JOIN Sessions ON " & _

   "Classes.Class_ID = Sessions.ClassID " & _

   "WHERE (((Sessions.Date)>Date())) " & _

   "ORDER BY Sessions.Date"

   rsUpcoming.Open strSqlUpcoming,cnEville_DB

   %>

   在ASP+中成了default.aspx:

   < %@ Import Namespace="System.Data" %>

   < %@ Import Namespace="System.Data.ADO" %>

   < %@ Register TagPrefix="seven" TagName="Connect" &_

   src="_includes/connect.aspc" %>

   < script language="vb" runat=server>

   Sub Page_Load(Source As Object, E As EventArgs)

   Dim dscUpcoming As ADODataSetCommand

   Dim dsUpcoming As New DataSet

   Dim strSQL As String

   strSQL = "SELECT TOP 2 Classes.Title," & _

   "Sessions.Session_ID, Classes.Description " & _

   "FROM Classes INNER JOIN Sessions ON " & _

   "Classes.Class_ID = Sessions.ClassID " & _

   "WHERE (((Sessions.Date)>Date())) " & _

   "ORDER BY Sessions.Date"

   dscUpcoming = New ADODataSetCommand(strSQL, Connect.ConnectToDB())

   dscUpcoming.FillDataSet(dsUpcoming, "Upcoming")

   End Sub

   < /script>

   數據訪問的核心,ANSI-SQL語句在轉換後沒有什麼改變。然而正如你所看到的,創建記錄集的結構發生了改變,我們使用的是ADODataSetCommand和DataSet。


相關文章: