如何在全局程序集缓存 (GAC) 中安装 DLL 文件

如何在全局程序集缓存 (GAC) 中安装 DLL 文件

要使用 Visual Studio .NET 创建小型类库项目、生成强名称,以及在 GAC 中安装项目的 .dll 文件,请执行下列步骤:

  1. 在 Visual Studio .NET 中,创建一个新 Visual C# .NET 类库项目,并将该项目命名为 GACDemo
  2. 必须使用强名称。要生成此加密密钥对,请使用 SN 工具。此工具位于安装 .NET Framework 解决方案开发人员工具包 (SDK) 的 \bin 子目录中。SN 工具易于使用。命令行语句采用以下形式:

** sn -k "[驱动器号]:\[放置密钥的目录]\[密钥名称].snk" **

  1. 在 C:\ 中创建一个名为 GACKey 的目录,以便您可以轻松地找到密钥,并从命令提示符处访问该密钥。

注意 :对于大多数用户,.NET 工具位于 C:\Program Files\Microsoft.NET\FrameworkSDK\Bin 中。键入以下 SN 命令前,可能需要在您的计算机上将与该路径类似的路径复制到 .NET bin 目录中。从命令提示符处键入 cd ,右键单击以粘贴该路径,然后按 ENTER 键,快速转至 SN 工具所在的目录。

键入以下内容:

sn -k "C:\GACKey\GACkey.snk"

  1. 将生成一个密钥,但是它与项目的程序集尚无关联。要建立此关联,请在 Visual Studio .NET 解决方案资源管理器中双击 AssemblyInfo.cs 文件。此文件具有一个程序集属性列表,默认情况下,在 Visual Studio .NET 中创建项目时将包括这些属性。在代码中修改“AssemblyKeyFile”程序集属性,如下所示:

[ assembly:AssemblyKeyFile("C:\\GACKey\\GACKey.snk") ]

通过按 CTRL+SHIFT+B 来编译项目。您不必具有任何附加代码即可以在 GAC 中安装 .dll 文件。 5. 您可以通过使用 Gacutil 工具或者通过将 .dll 文件拖至适当的目录来安装 .dll 文件。如果您使用 Gacutil 工具,则可以使用以下命令:

gacutil -I "[驱动器号]:\[VS 项目中 Bin 目录的路径]\gac.dll"

如果您要拖动文件,请使用 Microsoft Windows 资源管理器。打开 Windows 资源管理器的两个实例。在一个实例中,找到控制台项目的 .dll 文件输出的位置。在另一实例中,找到 c:\[SystemRoot]\Assembly。

将您的 .dll 文件拖到“Assembly”文件夹中。

完整代码列表 (AssemblyInfo.cs)

using System.Reflection;   
using System.Runtime.CompilerServices;   
//   
// General Information about an assembly is controlled through the following   
// set of attributes. Change these attribute values to modify the information   
// that is associated with an assembly.  
// 


[assembly: AssemblyTitle("")]   
[assembly: AssemblyDescription("")]   
[assembly: AssemblyConfiguration("")]   
[assembly: AssemblyCompany("")]   
[assembly: AssemblyProduct("")]   
[assembly: AssemblyCopyright("")]   
[assembly: AssemblyTrademark("")]   
[assembly: AssemblyCulture("")] 


  
//   
// Version information for an assembly is made up of the following four values:   
//   
// Major Version   
// Minor Version   
// Build Number   
// Revision   
//   
// You can specify all the values, or you can default the revision and build numbers   
// by using the '*' as shown below:   
[assembly: AssemblyVersion("1.0.*")]   
//   
// To sign your assembly you must specify a key to use. See the   
// Microsoft .NET Framework documentation for more information about assembly signing.   
//   
// Use the following attributes to control that key is used for signing.   
//   
// Notes:   
// (*) If no key is specified, the assembly is not signed.   
// (*) KeyName refers to a key that has been installed in the Crypto Service   
// Provider (CSP) on your computer. KeyFile refers to a file that contains   
// a key.   
// (*) If the KeyFile and the KeyName values are both specified, the   
// following processing occurs:   
// (1) If the KeyName can be found in the CSP, that key is used.   
// (2) If the KeyName does not exist and the KeyFile does exist, the key   
// in the KeyFile is installed to the CSP and used.   
// (*) To create a KeyFile, you can use the sn.exe (Strong Name) utility.   
// When specifying the KeyFile, the location of the KeyFile must be   
// relative to the project output directory which is   
// %Project Directory%\obj\. For example, if your KeyFile is   
// located in the project directory, you would specify the AssemblyKeyFile   
// attribute as [assembly: AssemblyKeyFile("..\\..\\mykey.snk")]   
// (*) Delay Signing is an advanced option - see the Microsoft .NET Framework   
// documentation for more information about this.   
// 


[assembly: AssemblyDelaySign(false)]   
[assembly: AssemblyKeyFile("C:\\GACKey\\GACKey.snk")]   
[assembly: AssemblyKeyName("")]
Published At
Categories with Web编程
Tagged with
comments powered by Disqus