關(guān)于程序集生成失敗 -- 引用的程序集沒有強(qiáng)名稱的解決辦法
?我在PetShop4程序中加入了一個業(yè)務(wù)外觀層,然后在業(yè)務(wù)邏輯層(PetShop.BLL)引用這個程序集,點(diǎn)“生成”,出現(xiàn)以下的錯誤:“程序集生成失敗 -- 引用的程序集沒有強(qiáng)名稱”,原因是PetShop.BLL是強(qiáng)命名程序集,強(qiáng)命名程序集不能用普通程序集造成的。
??????? 那么什么叫強(qiáng)命名程序集呢?我們知道,以前在Windows下開發(fā)程序時常會遭遇著名的“DLL Hell”問題,即動態(tài)鏈接庫的向后兼容問題。微軟在.Net產(chǎn)生前曾嘗試使用COM組件的方式來解決DLL Hell問題,即使用Guid來唯一的標(biāo)識每一個COM組件。但是,實(shí)際上使用COM組件(包括版本升級)也是一件頗為麻煩的事:為了運(yùn)行COM組件就必須在組冊表中對其進(jìn)行注冊,重新編譯有可能破壞Guid從而導(dǎo)致原來引用此COM組件的程序不能正確運(yùn)行,等等。
在.Net中,微軟引入了一種新的解決方案:強(qiáng)命名程序集(Strong Name),以及與之配套的全局程序集緩存(GAC)來解決這個問題。
我們知道,.Net使用Name、Version、Culture、PublicToken四個屬性來唯一標(biāo)識一個程序集,而不同產(chǎn)品前三個屬性(Name、Version和Culture)完全相同的情況是有可能發(fā)生的,如此一來,這唯一標(biāo)識程序集可重任就落到PublicToken的頭上了。強(qiáng)命名的程序集正是使用RSA來保證PublicToken的唯一性,因?yàn)樵诶碚撋希菍ΨQ算法RSA生成的公鑰/私鑰對不會重復(fù)。.Net正是通過在編譯項(xiàng)目時將指定的公鑰/私鑰對寫入程序集來保證其唯一性。
對于全局程序集緩存(GAC),MSDN是這樣介紹的:安裝有公共語言運(yùn)行庫的每臺計(jì)算機(jī)都具有稱為全局程序集緩存的計(jì)算機(jī)范圍內(nèi)的代碼緩存。全局程序集緩存中存儲了專門指定給由計(jì)算機(jī)中若干應(yīng)用程序共享的程序集。
在開發(fā)一般的、非共享的程序時,我們不需要使用強(qiáng)命名的程序集,僅將項(xiàng)目(Project)編輯成.DLL或者.EXE即可。但是,如果我們開發(fā)的是組件庫、框架時,通過對程序集進(jìn)行強(qiáng)命名,并使用將其部署到GAC中,可以保證我們的程序集不會出現(xiàn)版本問題。
那么,如何創(chuàng)建強(qiáng)命名的程序集呢?以下是其步驟
使用SN工具來生成密鑰對。該工具位于安裝.NET Framework SDK的Bin目錄中,在命令行中使用“?SN?-k [驅(qū)動器號]:[放置密鑰的目錄][密鑰名稱].snk ”這樣的語句可以生成密鑰對。如,我們使用?AssemblyInfo.cs 文件。此文件具有一個程序集屬性列表,默認(rèn)情況下,在 Visual Studio .NET 中創(chuàng)建項(xiàng)目時將包括這些屬性。在代碼中修改名為“AssemblyKeyFile”的屬性,如下所示:
[]
這樣,編譯該項(xiàng)目即生成強(qiáng)命名的程序集。
???????? 根據(jù)以上的說法,這個錯誤的解決問題如下:
首先打開visual studio 2005命令提示(開始-->程序-->microsoft visual studio 2005-->visual studio? tools-->visual studio 2005命令提示),在其中輸入:sn? -k? PetShop.IBLL.snk回車,這樣就生成了 PetShop.IBLL.snk,在路徑C:/Program Files/Microsoft Visual Studio 8/VC找到 PetShop.IBLL.snk文件,放在IBLL項(xiàng)目的根目錄也就是IBLL目錄下,然后打開BLL項(xiàng)目的AssemblyInfo.cs,在里面加入如下代碼行:[assembly: AssemblyKeyFile("PetSHop.IBLL.snk")], 然后重新生成PetShop.IBLL項(xiàng)目,這樣一個強(qiáng)命名的程序集就生成了。