新聞中心
由于我們的項(xiàng)目底層使用到一個(gè)通過LogicalCallContext實(shí)現(xiàn)的上下文數(shù)據(jù)管理框架,導(dǎo)致所有的Unit Test不能正常運(yùn)行。具體的現(xiàn)象在《只在UnitTest和WebHost中的出現(xiàn)的關(guān)于LogicalCallContext的嚴(yán)重問題》有過詳細(xì)的介紹。解決的方案就是對相關(guān)的程序集進(jìn)行強(qiáng)簽名,并加到GAC中,是Unit Test能夠識(shí)別基于LogicalCallContext項(xiàng)目的類型。有了Visual Studio這個(gè)強(qiáng)大的IDE,程序集的簽名工作很好實(shí)現(xiàn)——僅僅需要在Project的Properties對象框的Signing Tab中指定一個(gè)Key File就可以了。但是,Visual Studio做得不夠好。

一、Visual Studio會(huì)自作主張地在項(xiàng)目根目錄下復(fù)制一個(gè)Key File
舉個(gè)例子,假設(shè)一個(gè)解決方案中具有兩個(gè)項(xiàng)目:Lib1和Lib2。現(xiàn)在我們需要使用“同一個(gè)Key File”對Lib1和Lib2進(jìn)行簽名,Lib1、Lib2和Key File(Key.snk) 對應(yīng)的目錄結(jié)構(gòu)如右圖所示:Key.snk和Lib1和Lib2處在相同的目錄下面。
現(xiàn)在我們右擊Lib1項(xiàng)目文件,選擇Properties菜單項(xiàng)進(jìn)行項(xiàng)目屬性對話框,選擇Signing Tab頁進(jìn)行程序集簽名相關(guān)設(shè)置。選中Sign the assembly復(fù)選框,在下拉框中選擇
但是當(dāng)你選中Key.snk這個(gè)文件的時(shí)候,Visual Studio并不會(huì)用將這個(gè)文件作為對本程序集進(jìn)行簽名的Key File,而是會(huì)自作主張地將該文件拷貝到Lib1所在的根目錄下。最終被用于程序集簽名的不是我們希望的那個(gè)File Key,而是該File Key的復(fù)制品(如右圖所示)。
我不太明白微軟如此設(shè)計(jì)具有怎樣的考慮,但是對于我們目前的項(xiàng)目來說,我是無法接受的。上面的例子中只有兩個(gè)需要簽名的項(xiàng)目,就需要維護(hù)兩個(gè)Key File,但是我們的項(xiàng)目中有數(shù)十個(gè)項(xiàng)目,就意味著需要維護(hù)數(shù)十個(gè)不同的Key File,從維護(hù)的角度講,如果有朝一日我需要更換另一個(gè)Key File, 我就需要為每個(gè)項(xiàng)目進(jìn)行更新。
那么我們有沒有辦法讓所有項(xiàng)目采用同一個(gè)Key File進(jìn)行簽名呢?當(dāng)然有,不然我也不會(huì)寫這篇文章了。總的來說,我們?nèi)N不同的解決方案。
解決方案1:通過AssemblyKeyFileAttribute特性指定Key File
AssemblyKeyFileAttribute特性定義在System.Reflection命名空間下,專門用于指定在對項(xiàng)目進(jìn)行強(qiáng)簽名時(shí)采用的Key File。所以我們只需要在AssemblyInfo.cs中(也可以在其它地方)指定我們采用的Key File文件路徑即可。通過下面的代碼,我們指定我們對Lib1項(xiàng)目指定了我真正期望用于進(jìn)行簽名的那個(gè)Key File。
1: [assembly: AssemblyVersion("1.0.0.0")]
2: [assembly: AssemblyFileVersion("1.0.0.0")]
3: [assembly: AssemblyKeyFile("..\\Key.snk")]但是,這并不是一種推薦的Key File指定方式。當(dāng)你添加了AssemblyKeyFileAttribute特性的時(shí)候,Visual Studio會(huì)有如下一個(gè)警告:“Use command line option '/keyfile' or appropriate project settings instead of 'AssemblyKeyFile'”。提示你采用另外兩種方案:命令行或者項(xiàng)目設(shè)置。
解決方案2:通過命令行進(jìn)行強(qiáng)簽名
相信大家對通過命令行對程序集進(jìn)行強(qiáng)簽名的方式都不會(huì)感到陌生。這種方式就是直接使用.NET Framework為我們提供的強(qiáng)名稱工具(SN.exe: Strong Name Tool)。關(guān)于SN.exe相關(guān)參數(shù)設(shè)定可以參考MSDN在線文檔(http://msdn.microsoft.com/en-us/library/k5b5tt23(VS.80).aspx),在這里就不再贅言介紹了。
解決方案3:還是通過項(xiàng)目設(shè)置(Project Setting)
還是使用文章剛開始的那種方式,直接設(shè)置項(xiàng)目關(guān)于簽名(Signing)的相關(guān)屬性。有人會(huì)說了,你不是說這種方式會(huì)導(dǎo)致Key File的復(fù)制嗎,為何還要使用這種方式。為此,我們需要換一種思維:通過項(xiàng)目設(shè)置對象框?qū)?xiàng)目進(jìn)行的所有設(shè)置最終都會(huì)反映在項(xiàng)目文件中(.csproj或者.vbproj)。雖然通過Visual Studio不能實(shí)現(xiàn)我們的目標(biāo),如果我們直接更新項(xiàng)目文件呢?實(shí)踐證明,這種方案時(shí)可行的。為此,我們通過NotePad打開Lib1的項(xiàng)目文件Lib1.csproj,在
- ......
true ..\Key.snk
鏈接:http://www.cnblogs.com/artech/archive/2010/09/10/1823689.html
本文標(biāo)題:淺析VisualStudio中程序集簽名的不足之處
標(biāo)題路徑:http://fisionsoft.com.cn/article/cccsesi.html


咨詢
建站咨詢
