[摘 要] 本文主要介紹了ASP.NET語言的特性、在動態頁面中服務器、客戶端與數據庫的相關連接方法及其實現過程。適合應用于Access、SQL Server,以及其他相關數據庫的SQL訪問,是建立動態網站的有力工具。
[關鍵詞]ASP. NET 數據庫 動態 SQL
最近,一些基于TCP或IP的Internet或Intranet技術,被廣泛應用于各級企業網站,其中一個很重要的手段就是建立Web站點發布和瀏覽信息。傳統的靜態網頁技術已越來越不能滿足用戶的需求,因此各種動態網頁技術應運而生。ASP就是目前比較流行的動態網頁技術之一,而ASP. NET是微軟的新一代動態網頁技術。ASP. NET不是ASP的簡單升級,而是微軟公司推出的新一代Active Server Pages,是微軟公司推出的新一代體系結構Microsoft. NET的一部分。Microsoft. NET主要由W indows. NET、. NETFramework、. NET Enterp rise Server、Orchestration、MSN. NET、OFFICE. NET、Visual Studio. NET、bCentral. NET等部分組成。其中全新的技術架構會使編程變得更簡單,ASP. NET是在抓住ASP的最大優點并全力使其擴大化的基礎上開發出來的,同時也修復了許多ASP運行時會發生的錯誤。
一、ASP. NET的技術的發展及現狀
ASP. NET是建立在微軟新一代. NET平臺架構上, 利用普通語言運行時( CommonLanguageRuntime, CLR)在服務器后端為用戶提供建立強大的企業級Web應用服務的編程框架。ASP. NET可完全利用. NET架構的強大、安全和高效的平臺特性,是運行在服務器后端編譯后的普通語言運行時的代碼,運行時早綁定( Early B inding) 、即時編譯、本地優化、緩存服務、零安裝配置和基于運行時代碼受管與驗證的安全機制等都為ASP. NET帶來了卓越的性能。對XML,SOAP,WSDL等Internet標準的強有力的支持,為ASP. NET在異構網絡里提供了強大的擴展性。
二、ASP. NET的優點
1.支持多種腳本語言
ASP曾在腳本引擎方面受到限制,特別是VBScrip t和JavaScript。而ASP.NET可以支持VS.NET中的多種語言,例如C#、VB. Net等。這意味著可以擺脫VBScrip t的語言限制,代碼將是編譯后運行的而不是原來的解釋執行。
2.服務器處理
在Internet上作為服務發布的軟件是WebServices的核心。ASP. NET 提供了一個WebServices的基礎構造環境,從而使開發人員能夠為這個服務模型創建服務。Web Services的不同之處在于,它允許你暴露一個服務而不必暴露數據。當自動提供商業服務的同時,代碼和數據都是安全的。
3.代碼與內容的分離
通常ASP代碼是和內容混合在一起的,設計和編寫代碼同時進行會變得困難。如果頁面需要升級,就會存在危險的潛在問題。ASP. NET可通過兩種方法來解決這個問題。第一種是代碼內聯模型,在該模型中代碼仍然保存在ASP. NET頁面中,但它并不和HTML混合在一起。第二種分離代碼和內容的方法是代碼后置模型,該模型中的代碼被完全轉移到一個單獨的文件中。
4.更好的代碼控制
對于COM對象不再需要再在服務器上注冊這個功能,是非常受程序員喜愛的。但是通過這種過程簡化,你再也不能夠在你的服務器上運行另外一個DLL版本,并且代碼相當保密。這就意味著,如果沒有正確的開發工具和源代碼,很難改變代碼。
5.更好的升級能力
此系統建成,本身有著一定的特性,以改進多處理器環境中的性能。例如, session state能夠通過單獨的處理器來維持,在一個單獨的機器上,甚至在數據庫中允許交叉的服務器會話。
三、ASP. NET的運行環境
a. 服務器端:Windows 2003 Server。
b. 客戶端: Internet Exp lorer5.5以上。
c. ASP的開發環境:Visual Studio.NET 2005。
d. ASP. NET的開發語言: VB.NET,C#。
四、ASP. NET與WEB數據庫的連接
ASP. NET不僅帶來了ADO.NET,還帶來了SQL Managed Provider。這樣在ASP.NET里,我們就有了三種連接數據庫的方式:
(1)ADO. NETManaged Provider
(2)SQL Managed Provider
(3)ADO. NETManaged Provider +ODBC
其中,方式(1)可以連接到任何ODBC 或者OLEDB數據中心,而方式(2)可以連接到MS SQLServer。三種方法的對比如下:
一般來說,這三種存取數據庫的方法中, SQL Managed Provider 效率最高, 其次是ADO. NETManaged Provider + OLEDB,最差的是ADO. NETManaged Provider +ODBC。
SQL Managed Provider要優于ADO.NET Managed Provider, 而從ODBC 和OLEDB的對比來看,OLEDB要優于ODBC。
ASP. Net與Access數據庫連接:
< %@ Import Namespace =“system. data. oledb”%>
< %@ Import Namespace =“system. data”%>
< %@ Import Namespace =”System. IO“%>
< %Dim dbconn asOledbConnectiondbconn = new OledbConnection (”p rovider = microsoft. jet. oledb. 4.0; data source=“ server.MapPath (“XXX. mdb”))%>
ASP. Net與SQL數據庫連接:
< %@ Import Namespace =“system. data. oledb”% >
< %@ Import Namespace =“system. data”% >
< %@ Import Namespace =“System. IO”% >
< % Dim dbconn asOledbConnectiondbconn = new OledbConnection (“ p rovider =sqloledb; server =主機名稱; initial catalog =數據庫名稱; user id =XXX; password =XXX; ” ) % >建立記錄集對象:
< %Dim i as integerDim sql as OledbDataAdap terDim ds as new datasetsql = new OledbDataAdap ter (“ select 3 from contact” , dbconn)sql. fill ( ds, “ guest” ) % >
五、總結
ASP. NET從現有的ASP結構體系上跨出了一大步, 其整個構造體系使開發結構化的應用程序變為可能。Web表單設計帶來了一種更加直接和易于使用的開發模式。服務器控件增加了提供公共功能的能力,從而使擴展和加強現有功能變得容易。數據捆綁使創建數據約束型應用程序變得十分簡單。它不但具有許多很棒的新功能,而且還有一個用于開發Web應用程序的真正框架。使用ASP. NET的組件,可以輕松地實現對網頁內容的動態控制,根據不同的瀏覽者,生成不同的頁面內容。在ADO. NET的支持下, ASP. NET與遠程主機上的數據庫的連接與操作變得非常簡單。隨著越來越多的開發者開始使用這種新技術,給Internet的發展帶來了一次新的浪潮。
參考文獻:
[1]曹建英:ASP.NET的安全性及其實現的策略[J].溫州師范學院學報, 2005,(02)
[2]蘭靜:基于ASP.NET的在線考試系統[J].山西廣播電視大學學報, 2005,(02)
[3]李曉念:在ASP.NET環境下實現圖像文件上傳及其屬性修改[J].廣西教育學院學報, 2004,(03)
[4]黃 悅:基于ASP.NET與XML的網絡硬盤開發[J].長沙通信職業技術學院學報, 2005,(02)