日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

依賴注入機制及IoC的設計與實現(xiàn)_.Net教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:近期的幾個ASP.NET開發(fā)經(jīng)驗總結(jié)和收集
一:頁面中Page_Load事件 和 Page.IsPostBack執(zhí)行兩次的原因. 原因一: 當<%@Page....中沒有AutoEventWireup定義時會導致Page_Load執(zhí)行兩次,如果有定義,且值為true時,在IsPostBack中動態(tài)

我們設計的分層架構(gòu),層與層之間應該是松散耦合的。因為是單向單一調(diào)用,所以,這里的“松散耦合”實際是指上層類不能具體依賴于下層類,而應該依賴于下層提供的一個接口。這樣,上層類不能直接實例化下層中的類,而只持有接口,至于接口所指變量最終究竟是哪一個類,則由依賴注入機制決定。

之所以這樣做,是為了實現(xiàn)層與層之間的“可替換”式設計,例如,現(xiàn)在需要換一種方式實現(xiàn)數(shù)據(jù)訪問層,只要這個實現(xiàn)遵循了前面定義的數(shù)據(jù)訪問層接口,業(yè)務邏輯層和表示層不需要做任何改動,只需要改一下配置文件系統(tǒng)即可正常運行。另外,基于這種結(jié)構(gòu)的系統(tǒng),還可以實現(xiàn)并行開發(fā)。即不同開發(fā)人員可以專注于自己的層次,只有接口被定義好了,開發(fā)出來的東西就可以無縫連接。

在J2EE平臺上,主要使用Spring框架實現(xiàn)依賴注入。這里,我們將自己做一個依賴注入容器。

依賴注入的理論基礎是Abstract Factory設計模式,這里結(jié)合具體實例簡單介紹一下。

上圖以數(shù)據(jù)訪問層為例,展示了Abstract Factory模式的應用。如圖,現(xiàn)假設有針對Access和SQLServer兩種數(shù)據(jù)庫的數(shù)據(jù)訪問層,它們都實現(xiàn)了數(shù)據(jù)訪問層接口。每個數(shù)據(jù)訪問層有自己的工廠,所有工廠都實現(xiàn)自IDALFactory接口。而客戶類(這里就是業(yè)務邏輯層類)僅與工廠接口、數(shù)據(jù)訪問層接口耦合,而與具體類無關(guān),這樣,只要通過配置文件確定實例化哪個工廠,就可以得到不同的數(shù)據(jù)訪問層。

然而,這種設計雖然可行,但是代碼比較冗余,因為這樣需要為數(shù)據(jù)訪問層的每一個實現(xiàn)編寫一個工廠,業(yè)務邏輯層也一樣。在以前,我們毫無辦法,但是,.NET平臺引入的反射機制,給我們提供了一種解決方案。使用反射,每個層只需要一個工廠,然后通過從配置文件中讀出程序集的名稱,動態(tài)加載相應類。另外,為了提高依賴注入機制的效率,這里引入緩存機制。下面來看具體實現(xiàn)。

配置

首先,需要在Web工程的Web.config文件的<appSettings>節(jié)點下添加如下兩個項:
<add key="DAL" value=""/>
<add key="BLL" value=""/>

這兩個配置選項分別存儲要應用的數(shù)據(jù)訪問和也業(yè)務邏輯層的程序集名稱。value目前是空,是因為目前還沒有各個層次的具體實現(xiàn)。

實現(xiàn)緩存操作輔助類

為實現(xiàn)緩存操作,我們將緩存操作封裝成一個輔助類,放在Utility工程下,具體代碼如下:

using System;
using System.Web;
using System.Web.Caching;

namespace NGuestBook.Utility
{
/**//// <summary>
/// 輔助類,用于緩存操作
/// </summary>
public sealed class CacheAccess
{
/**//// <summary>
/// 將對象加入到緩存中
/// </summary>
/// <param name="cacheKey">緩存鍵</param>
/// <param name="cacheObject">緩存對象</param>
/// <param name="dependency">緩存依賴項</param>
public static void SaveToCache(string cacheKey, object cacheObject, CacheDependency dependency)
{
Cache cache = HttpRuntime.Cache;
cache.Insert(cacheKey, cacheObject, dependency);
}

/**//// <summary>
/// 從緩存中取得對象,不存在則返回null
/// </summary>
/// <param name="cacheKey">緩存鍵</param>
/// <returns>獲取的緩存對象</returns>
public static object GetFromCache(string cacheKey)
{
Cache cache = HttpRuntime.Cache;

return cache[cacheKey];
}
}
}

封裝依賴注入代碼

因為很多依賴注入代碼非常相似,為了減少重復性代碼,我們將可復用的代碼先封裝在一個類中。具體代碼如下(這個類放在Factory工程下):

using System;
using System.Configuration;
using System.Reflection;
using System.Web;
using System.Web.Caching;
using NGuestBook.Utility;

namespace NGuestBook.Factory
{
/**//// <summary>
/// 依賴注入提供者
/// 使用反射機制實現(xiàn)
/// </summary>
public sealed class DependencyInjector
{
/**//// <summary>
/// 取得數(shù)據(jù)訪問層對象
/// 首先檢查緩存中是否存在,如果不存在,則利用反射機制返回對象
/// </summary>
/// <param name="className">數(shù)據(jù)訪問類名稱</param>
/// <returns>數(shù)據(jù)訪問層對象</returns>
public static object GetDALObject(string className)
{
/**//// <summary>
/// 取得數(shù)據(jù)訪問層名稱,首先檢查緩存,不存在則到配置文件中讀取
/// 緩存依賴項為Web.Config文件
/// </summary>
object dal = CacheAccess.GetFromCache("DAL");
if (dal == null)
{
CacheDependency fileDependency = new CacheDependency(HttpContext.Current.Server.MapPath("Web.Config"));
dal = ConfigurationManager.AppSettings["DAL"];
CacheAccess.SaveToCache("DAL", dal, fileDependency);
}

/**//// <summary>
/// 取得數(shù)據(jù)訪問層對象
/// </summary>
string dalName = (string)dal;
string fullClassName = dalName "." className;
object dalObject = CacheAccess.GetFromCache(className);
if (dalObject == null)
{
CacheDependency fileDependency = new CacheDependency(HttpContext.Current.Server.MapPath("Web.Config"));
dalObject = Assembly.Load(dalName).CreateInstance(fullClassName);
CacheAccess.SaveToCache(className, dalObject, fileDependency);
}

return dalObject;
}

/**//// <summary>
/// 取得業(yè)務邏輯層對象
/// 首先檢查緩存中是否存在,如果不存在,則利用反射機制返回對象
/// </summary>
/// <param name="className">業(yè)務邏輯類名稱</param>
/// <returns>業(yè)務邏輯層對象</returns>
public static object GetBLLObject(string className)
{
/**//// <summary>
/// 取得業(yè)務邏輯層名稱,首先檢查緩存,不存在則到配置文件中讀取
/// 緩存依賴項為Web.Config文件
/// </summary>
object bll = CacheAccess.GetFromCache("BLL");
if (bll == null)
{
CacheDependency fileDependency = new CacheDependency(HttpContext.Current.Server.MapPath("Web.Config"));
bll = ConfigurationManager.AppSettings["BLL"];
CacheAccess.SaveToCache("BLL", bll, fileDependency);
}

/**//// <summary>
/// 取得業(yè)務邏輯層對象
/// </summary>
string bllName = (string)bll;
string fullClassName = bllName "." className;
object bllObject = CacheAccess.GetFromCache(className);
if (bllObject == null)
{
CacheDependency fileDependency = new CacheDependency(HttpContext.Current.Server.MapPath("Web.Config"));
bllObject = Assembly.Load(bllName).CreateInstance(fullClassName);
CacheAccess.SaveToCache(className, bllObject, fileDependency);
}

return bllObject;
}
}
}

分享:.NET平臺依賴注入機制及IoC的設計與實現(xiàn)
我們設計的分層架構(gòu),層與層之間應該是松散耦合的。因為是單向單一調(diào)用,所以,這里的“松散耦合”實際是指上層類不能具體依賴于下層類,而應該依賴于下層提供的一個接口。這樣,上層

共2頁上一頁12下一頁
來源:模板無憂//所屬分類:.Net教程/更新時間:2008-08-22
相關(guān).Net教程