在我的web和worker角色中,我引用了核心框架DLL的替代版本。該文件標記爲Copy Local
。 Visual Studio在項目引用中顯示正確的版本。編譯項目時,bin
目錄也包含正確的版本。Azure包中包含不正確的DLL
但是,當我要求Visual Studio創建一個Azure包時,該包(以及包裝期間創建的csx
文件夾)僅包含用於Worker角色的錯誤(原始)DLL。 Web角色具有正確的DLL。如果我手動使用cspack
,則不會發生這種情況,但這不是一個真正想要打包的方法。
什麼會導致Visual Studio使用正確的引用DLL進行編譯,但綁定了錯誤的引用?
附加信息: 當我運行msbuild
做包裝,而不是Visual Studio中,我看到了下面兩行:
Copying file from "C:\Users\bytenik\Dropbox\Treadmarks\lib\EntityFramework\System.Data.Entity.dll" to "C:\Users\bytenik\Dropbox\Treadmarks\src\Azure\obj\Debug\Worker\System.Data.Entity.dll".
Copying file from "C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETFramework\v4.0\System.Data.Entity.dll" to "C:\Users\bytenik\Dropbox\Treadmarks\src\Azure\obj\Debug\Worker\System.Data.Entity.dll".
因此,它似乎複製我的參考,然後在它複製與系統參考。
注意:我很清楚替換.NET CLR DLL的整個概念是一個巨大的破解。當.NET 4.5出來支持我需要的功能時,這一切都將被剝離。同時,我需要能夠繼續發展。
這是對問題「Azure References Incorrect DLL」的替換,它實際上是不正確的,並導致有效的答案,但沒有解決我的問題。
以供將來參考它會更好重新寫了原來的問題。謝謝。 – Kev 2012-02-14 15:51:22
@Kev我想過,但所有的答案都沒有意義。 – 2012-02-14 15:53:43