亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

ADO.NET實用技巧兩則

2020-01-24 03:50:25
字體:
來源:轉載
供稿:網友
要想充分發揮ADO.NET的優勢,不僅需要全面、深入理解ADO.NET編程模型,及時總結經驗、技巧也十分重要。ADO已經有多年的實踐經驗,ADO.NET以此為基礎,提供了更加豐富、強大的工具;盡管如此,ADO.NET的設計目標畢竟不是提供一個即插即用的工具,它不會把所有的編程工作簡化到僅靠鼠標點擊就可以完成的程度。 

  ADO.NET包含了一大堆代表數據訪問模型中各種邏輯實體的對象,其中尤以連接、事務這兩個對象最為重要。連接的作用是建立一個與后端數據庫通信的通道,創建連接對象必須以特定的.NET數據提供者為基礎。事務對象可以在已有的連接對象上創建,也可以通過顯式地執行一個BEGIN TRAN SQL語句創建。雖然理論很簡單,但實際上,圍繞連接、事務的不確定因素很多,而且它們對應用整體的穩定性和效率有著至關緊要的影響。 

  如何保存連接字符串,保護連接字符串中可能包含的敏感信息(例如密碼)?怎樣設計一個完善的數據訪問策略,既考慮到安全性(即身份驗證、授權),卻又不至于對性能和可伸縮性造成太大的影響?如果需要用到事務,那么如何高效地實現和控制事務?采用自動事務還是手動事務?在使用ADO.NET時,這些問題都必須仔細考慮。 

  一、連接字符串,連接池 

  數據庫連接是一種重要的、有限的、開銷昂貴的資源,因此用好連接對象是任何應用的最基本的要求。使用數據庫連接的要點可總結如下: 

  保存連接字符串應注意安全。
  打開連接應遲,關閉連接應早。
  連接字符串是訪問數據庫的鑰匙。連接字符串除了說明要訪問的數據之外,還包含了用戶為什么可以訪問那些數據的身份證明。在執行數據庫操作時,用戶身份證明是確定數據訪問權限的最重要的因素。 

  1.1 保存連接字符串 

  目前,硬編碼的連接字符串具有最好的性能,因為它們直接編譯進了應用的代碼之中。然而,硬編碼的字符串影響程序的靈活性,一旦連接字符串改變,應用程序必須重新編譯。 

  將連接字符串保存到外部提高了靈活性,代價是訪問外部字符串需要付出額外的開銷。但在絕大多數情況下,由此導致的性能開銷可以忽略不計,真正需要擔心的是安全問題。例如,攻擊者可能修改、竊取連接字符串。將連接字符串保存到外部環境的常見途徑有:配置文件,UDL文件,Windows注冊表。 

  .NET框架配置文件以純文本文件的形式部署,訪問方便。如果連接字符串包含密碼,文本格式將是最大的缺陷所在,因為密碼將以明文的形式保存??梢钥紤]引入一個專用的加密/解密引擎,不過這部分工作需要開發者自己完成。 

  UDL文件是供OLE DB提供者使用的文本文件,也就是說,SQL Server托管提供者不支持UDL文件。UDL文件也存在和前面的配置文件一樣的安全問題,總地看來優勢不多。 

  最后,Windows注冊表可以作為一個天然安全的存儲場所。注冊表是一個保存關鍵信息的系統知識庫,如果結合運用加密技術,可以達到較高的安全性。使用注冊表的主要缺點是部署麻煩,要求創建注冊鍵(可能還要執行加密)以及從注冊表讀取數據。雖然.NET Framework提供了一組調用底層Win32 API的封裝類,但這些類都沒有提供加密功能。aspnet_setreg.exe工具可以用來創建HKEY_LOCAL_MACHINE下的注冊鍵保存用戶名稱和密碼,例如:aspnet_setreg.exe -k "Software/MyData" -u:userID -p:password。該命令將加密指定的用戶ID和密碼。 

  1.2 連接池原理 

  連接池允許我們通過一個緩沖池重用現有的連接對象,避免每次使用連接對象時都要新建一個對象。采用連接池之后,只要少量的連接對象就可以滿足大量客戶端的需要。 

  每一個連接池都與一個獨立的連接字符串及其事務上下文關聯。每次打開一個新的連接,數據提供者會嘗試將指定的連接字符串與連接池的字符串進行匹配。如果匹配失敗,數據提供者創建一個新的連接并將它加入連接池。連接池被創建之后,除非進程結束,否則不會被拆除。有人認為這種處理方式會影響性能,其實不然,維護一個不活動的或者空的連接池不需要多少開銷。 

  連接池創建之后,系統會創建一些連接對象并將它們加入連接池,直至達到額定的最小連接對象數量。以后,系統會根據需要新建和加入連接對象,一直到達最大連接對象數量限額為止。如果程序請求一個連接對象時沒有空閑的連接對象可用,且連接池里面的對象數量已達到上限,則請求被放入隊列,一旦有連接被釋放回緩沖池就立即取出使用。 

  避免用編程的方式構造連接字符串。如果通過合并多個輸入數據的方式構造出連接字符串,很容易給注入式攻擊以可乘之機。如果必須用到用戶輸入的數據,務必進行嚴格的驗證。 

  1.3 關閉連接 

  關閉一個連接時,連接對象被返回給連接池以便重用,但這時實際的數據庫連接并未被拆除。如果禁用了連接池,則實際的數據庫連接也被關閉。這里必須強調的一點時,連接對象使用完畢后應當顯式關閉并將它返回給連接池,不要依靠垃圾收集器來釋放連接。實際上,當連接對象的引用超出有效范圍時,連接不一定被關閉――垃圾收集器的功能是拆除代表物理連接的.NET封裝對象,但這并不意味著底層的連接也被關閉了。 
 調用Close或Dispose方法可以將連接釋放回連接池。只有當生存期結束或出現嚴重錯誤時,連接對象才會被從連接池刪除。 

  1.4 連接池與安全 

  如果一個應用程序的所有數據訪問操作都使用同樣的連接字符串,連接池的優勢將發揮到極限。但是,這只是一種理想化了的狀況,很可能與應用程序的其他要求存在沖突。例如,如果只使用一個連接字符串,要在數據庫這一層次上執行安全控制就很困難了。 

  另一方面,如果讓每一個用戶分別使用自己的連接字符串(即為每一個用戶分別設定數據庫帳戶),勢必出現大量小型的連接池,許多連接根本不會被重用。依照慣例,這類問題的最佳解決方案是尋找兩個極端之間的一個適當折衷點。我們可以設置一組具有代表性的公用帳戶,同時修改存儲過程,使之接受一個表示用戶標識的參數,存儲過程根據傳入的用戶標識執行不同的操作。

  二、事務模式 

  分布式企業應用離不開事務。在數據訪問代碼中加入事務管理功能主要有兩種方式:手動方式,自動方式。 

  在手動方式中,程序員負責編寫所有配置、使用事務機制的代碼。自動(或COM+)事務則在.NET類中加入聲明式屬性,指定運行時對象的事務特性。自動方式方便了將多個組件配制成在同一個事務之內運行。兩種事務方式都支持本地的或分布式的事務,但自動的事務方式極大地簡化了分布式事務處理。 

  必須注意的是,事務是一種開銷很大的操作,所以決定使用事務之前務必再三考慮。如果確實需要使用事務,那就要盡量縮小事務的粒度,減少對數據庫的加鎖時間、加鎖范圍。例如,對于SQL Server,單個的SQL語句不需要顯式地聲明事務,SQL Server會自動將每一個語句作為一個獨立的事務運行。手動的本地事務總是比其他事務快得多,因為它不需要涉及DTC(Distributed Transaction Coordinator)。 

  手動事務、自動事務應當視為兩種不同的、互斥的技術。如果要在單個數據庫上執行事務性操作,優先考慮手動事務。當單個事務跨越多個遠程數據庫,或單個事務涉及多個資源管理器(例如,一個數據庫和一個MSMQ資源管理器),優先考慮自動事務。不管怎樣,應當極力避免混合運用兩種事務模式。如果性能不是特別重要,即使只對一個數據庫操作也可以考慮使用自動事務,使代碼更加簡潔(但速度略慢)。 

  總而言之,要提高數據庫訪問代碼的質量,必須深入了解ADO.NET對象模型,根據實際情況靈活運用各種技巧。ADO.NET是一個公用的API,各種應用――不管是Windows窗體應用、ASP頁面還是Web服務,都可以通過ADO.NET訪問數據庫;但是,ADO.NET不是一邊接受輸入、一邊吐出結果的黑箱,而是一個由許多工具組成的工具箱。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美一区二区大胆人体摄影专业网站| 亚州成人av在线| 久久精品视频播放| 欧美在线免费观看| 亚洲精品v欧美精品v日韩精品| 不卡中文字幕av| 欧美电影免费观看高清完整| 国产999精品久久久影片官网| 中文字幕少妇一区二区三区| 成人免费福利视频| 日韩有码在线电影| 伊人成人开心激情综合网| 91精品视频大全| 国语自产精品视频在免费| 亚洲精品综合久久中文字幕| 成人av电影天堂| 欧美激情国产高清| 久久久99免费视频| 91最新在线免费观看| 亚洲永久在线观看| 亚洲色图狂野欧美| 成人激情电影一区二区| 国产香蕉一区二区三区在线视频| 亚洲欧美制服中文字幕| 日本高清视频精品| 亚洲欧美日韩国产成人| 91久久国产婷婷一区二区| 亚洲成人久久电影| 国产精品高清免费在线观看| 色综合久久中文字幕综合网小说| 日韩av电影手机在线观看| 欧美一级黑人aaaaaaa做受| 亚洲第一视频网站| 国语自产精品视频在线看抢先版图片| 国内免费久久久久久久久久久| 亚洲精品国产精品国自产观看浪潮| 蜜臀久久99精品久久久久久宅男| 日韩av男人的天堂| 欧美乱大交xxxxx另类电影| 欧美一级片免费在线| 欧美肥臀大乳一区二区免费视频| 一本久久综合亚洲鲁鲁| 日韩av手机在线观看| 亚洲成色www8888| 国产视频久久网| 久久久亚洲网站| 欧美大片网站在线观看| 91免费看国产| 91在线视频精品| 国产精品国模在线| 亚洲国产精品高清久久久| 精品国偷自产在线| 91在线看www| 成人网在线观看| 久久精品视频免费播放| 色老头一区二区三区在线观看| 欧美孕妇与黑人孕交| 一区二区三区亚洲| 亚洲视频axxx| 亚洲国产精彩中文乱码av| 亚洲国产精品999| 国内成人精品一区| 一区二区三区国产视频| 久久九九全国免费精品观看| 91丨九色丨国产在线| 欧美另类极品videosbest最新版本| 日韩在线视频观看正片免费网站| 日韩久久精品电影| 国产视频精品一区二区三区| 亚洲欧美国产一区二区三区| 亚洲综合精品一区二区| 久久久91精品国产一区不卡| 色中色综合影院手机版在线观看| 中文字幕欧美视频在线| 国产成人综合久久| 日韩精品中文字幕在线播放| 日韩中文字幕久久| 久久久久久久久爱| 日韩h在线观看| 国产成人精品在线播放| 4438全国亚洲精品在线观看视频| 亚洲国产97在线精品一区| 九九九久久久久久| 中文字幕视频一区二区在线有码| 国产精品高潮呻吟久久av野狼| www.久久色.com| 国产精品久在线观看| 欧美巨大黑人极品精男| 日韩欧美视频一区二区三区| 91高清视频免费观看| 欧美亚洲伦理www| 日韩av色在线| 日韩av网址在线| 日韩欧美高清在线视频| 亚洲精品国产精品久久清纯直播| 久久九九免费视频| 亚洲欧美成人在线| 国产日韩换脸av一区在线观看| 一区二区三区国产在线观看| 国产女人精品视频| 久久免费视频在线| 伊人久久久久久久久久久| 精品性高朝久久久久久久| 国产欧美在线播放| 亚洲精品视频在线观看视频| 国产一区二区三区毛片| 久久高清视频免费| 亚洲女人天堂成人av在线| 色婷婷av一区二区三区久久| 国产精品午夜一区二区欲梦| 91久久久国产精品| 在线免费观看羞羞视频一区二区| 成人444kkkk在线观看| 911国产网站尤物在线观看| 久热99视频在线观看| 91av网站在线播放| 亚洲激情 国产| 欧美性受xxx| 久久99久久99精品中文字幕| 97超级碰碰碰| 国产成人精品日本亚洲| 夜夜狂射影院欧美极品| 久久久久久久久爱| 日本老师69xxx| 国产日产欧美精品| 黄色91在线观看| 欧美日韩国产一区中文午夜| 久久色免费在线视频| 97在线视频免费播放| 欧美成人精品在线播放| 成人福利网站在线观看| 国产成人亚洲综合91精品| 98精品国产高清在线xxxx天堂| 91色视频在线导航| 国产精品亚洲一区二区三区| zzjj国产精品一区二区| 日韩电影免费观看在线| 国产+成+人+亚洲欧洲| 亚洲xxx自由成熟| 综合136福利视频在线| 91久久嫩草影院一区二区| 国产精品jvid在线观看蜜臀| 亚洲白虎美女被爆操| 91影视免费在线观看| 性日韩欧美在线视频| 日韩人体视频一二区| 川上优av一区二区线观看| 日韩中文字幕在线视频| 欧美日韩一区免费| 亚洲一区二区在线播放| 亚洲成人免费在线视频| 亚洲一区二区三区sesese| 久久久久久久久久久久av| 97热在线精品视频在线观看| 日韩福利伦理影院免费| 中文字幕欧美精品在线| 亚洲福利在线播放| xvideos亚洲| 亚洲最大成人免费视频| 国产亚洲精品激情久久| 欧美高清videos高潮hd| 最近2019中文字幕第三页视频| 亚洲精品美女网站| 国产精品久久久久久久久久久久|