创建一个强名称密钥文件+ 如何在 Visual C# .NET 中将程序集安装到全局程序集缓存中
- 
    单击“开始”,依次指向“程序”、“Microsoft Visual Studio 2005”、“Visual Studio 工具”,然后单击“Visual Studio 2005 命令提示”。
    2 .  在命令提示符下,键入 sn -k Tutorial.snk,然后按 Enter。 
    这里关键的是 sn -k *.snk
From: http://support.microsoft.com/?scid=kb;zh-cn;815808&spid=1108&sid=152
如何在 Visual C# .NET 中将程序集安装到全局程序集缓存中
概要
本文介绍如何为程序集生成强名称,以及如何在全局程序集缓存 (GAC) 中安装 DLL 文件。通过 GAC,您可以在许多应用程序之间共享程序集。GAC 随 .NET 运行库一起自动安装。组件通常存储在 C:\WINNT\Assembly 中。
要在 GAC 中安装程序集,必须为程序集指定强名称。该名称是加密的哈希密钥或签名。这种强名称可确保正确的组件版本控制。这有助于防止具有相同名称的组件相互冲突或被消耗应用程序误用。
要求
下面概括列出了推荐的硬件、软件、网络结构以及所需的 Service Pack: • 对安装共享程序集的计算机的管理员权限 
本文假定您熟悉下列主题: • 大体熟悉 .NET 中的程序集 
• 大体熟悉从命令提示符处使用工具 
全局程序集缓存
要使用 Visual Studio .NET 创建小型类库项目、生成强名称,以及在 GAC 中安装项目的 .dll 文件,请按照下列步骤操作: 1. 在 Visual Studio .NET 中,创建一个新 Visual C# .NET 类库项目,并将该项目命名为 GACDemo。 
2. 必须使用强名称。要生成此加密密钥对,请使用 SN 工具。此工具位于安装 .NET Framework 解决方案开发人员工具包 (SDK) 的 \bin 子目录中。SN 工具易于使用。命令行语句采用以下形式:
sn -k "[DriveLetter]:\[DirectoryToPlaceKey]\[KeyName].snk" 
3. 在 C:\ 中创建一个名为 GACKey 的目录,以便您可以轻松地找到密钥,并从命令提示符处访问该密钥。
注意:对于大多数用户,.NET 工具位于 C:\Program Files\Microsoft.NET\FrameworkSDK\Bin 中。键入以下 SN 命令前,可能需要在您的计算机上将与该路径类似的路径复制到 .NET bin 目录中。从命令提示符处键入 cd,右键单击以粘贴该路径,然后按 Enter,快速转至 SN 工具所在的目录。
键入以下内容:
sn -k "C:\GACKey\GACkey.snk" 
4. 将生成一个密钥,但是它与项目的程序集尚无关联。要建立此关联,请在 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 "[DriveLetter]:\[PathToBinDirectoryInVSProject]\gac.dll"
如果您要拖动文件,请使用 Microsoft Windows 资源管理器。打开 Windows 资源管理器的两个实例。在一个实例中,找到控制台项目的 .dll 文件输出的位置。在另一实例中,找到 c:\[SystemRoot]\Assembly。
将您的 .dll 文件拖到“Assembly”文件夹中。 
完整代码列表 (AssemblyInfo.cs)

 using System.Reflection;
using System.Reflection; using System.Runtime.CompilerServices;
using System.Runtime.CompilerServices;
 //
// // General Information about an assembly is controlled through the following
// General Information about an assembly is controlled through the following  // set of attributes. Change these attribute values to modify the information
// set of attributes. Change these attribute values to modify the information // that is associated with an assembly.
// that is associated with an assembly. //
// [assembly: AssemblyTitle("")]
[assembly: AssemblyTitle("")] [assembly: AssemblyDescription("")]
[assembly: AssemblyDescription("")] [assembly: AssemblyConfiguration("")]
[assembly: AssemblyConfiguration("")] [assembly: AssemblyCompany("")]
[assembly: AssemblyCompany("")] [assembly: AssemblyProduct("")]
[assembly: AssemblyProduct("")] [assembly: AssemblyCopyright("")]
[assembly: AssemblyCopyright("")] [assembly: AssemblyTrademark("")]
[assembly: AssemblyTrademark("")] [assembly: AssemblyCulture("")]
[assembly: AssemblyCulture("")]
 //
// // Version information for an assembly is made up of the following four values:
// Version information for an assembly is made up of the following four values: //
// //      Major Version
//      Major Version //      Minor Version
//      Minor Version  //      Build Number
//      Build Number //      Revision
//      Revision //
// // You can specify all the values, or you can default the revision and build numbers
// You can specify all the values, or you can default the revision and build numbers  // by using the '*' as shown below:
// by using the '*' as shown below:
 [assembly: AssemblyVersion("1.0.*")]
[assembly: AssemblyVersion("1.0.*")]
 //
// // To sign your assembly you must specify a key to use. See the
// To sign your assembly you must specify a key to use. See the  // Microsoft .NET Framework documentation for more information about assembly signing.
// Microsoft .NET Framework documentation for more information about assembly signing. //
// // Use the following attributes to control that key is used for signing.
// Use the following attributes to control that key is used for signing.  //
// // Notes:
// Notes:  //   (*) If no key is specified, the assembly is not signed.
//   (*) If no key is specified, the assembly is not signed. //   (*) KeyName refers to a key that has been installed in the Crypto Service
//   (*) 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
//       Provider (CSP) on your computer. KeyFile refers to a file that contains //       a key.
//       a key. //   (*) If the KeyFile and the KeyName values are both specified, the
//   (*) If the KeyFile and the KeyName values are both specified, the  //       following processing occurs:
//       following processing occurs: //       (1) If the KeyName can be found in the CSP, that key is used.
//       (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
//       (2) If the KeyName does not exist and the KeyFile does exist, the key  //           in the KeyFile is installed to the CSP and used.
//           in the KeyFile is installed to the CSP and used. //   (*) To create a KeyFile, you can use the sn.exe (Strong Name) utility.
//   (*) To create a KeyFile, you can use the sn.exe (Strong Name) utility. //       When specifying the KeyFile, the location of the KeyFile must be
//       When specifying the KeyFile, the location of the KeyFile must be //       relative to the project output directory which is
//       relative to the project output directory which is //       %Project Directory%\obj\<configuration>. For example, if your KeyFile is
//       %Project Directory%\obj\<configuration>. For example, if your KeyFile is //       located in the project directory, you would specify the AssemblyKeyFile
//       located in the project directory, you would specify the AssemblyKeyFile  //       attribute as [assembly: AssemblyKeyFile("..\\..\\mykey.snk")]
//       attribute as [assembly: AssemblyKeyFile("..\\..\\mykey.snk")] //   (*) Delay Signing is an advanced option - see the Microsoft .NET Framework
//   (*) Delay Signing is an advanced option - see the Microsoft .NET Framework //       documentation for more information about this.
//       documentation for more information about this. //
// [assembly: AssemblyDelaySign(false)]
[assembly: AssemblyDelaySign(false)] [assembly: AssemblyKeyFile("C:\\GACKey\\GACKey.snk")]
[assembly: AssemblyKeyFile("C:\\GACKey\\GACKey.snk")] [assembly: AssemblyKeyName("")]
[assembly: AssemblyKeyName("")]
From:
http://www.dnnchina.net/Default.aspx?tabid=455&ctl=ArticleView&mid=1153&articleId=50
许多应用程序都使用由多个应用程序共享的程序集。这些程序集通常由第三方开发商提供,安装在系统中的公用位置——全局程序集缓存中。默认情况下,系统在全局程序集缓存中查找每一个应用程序的程序集。必须拥有管理员的权限才能将程序集安装到全局程序集缓存中。安装在全局程序集缓存中的每一个程序集都必须拥有一个强名称。通过gacutil.exe可以访问全局程序集中的缓冲对象。Gacutil –i添加,gacutil –u移除,gacutil –l查询。C:\WINDOWS\assembly
 
 
                    
                 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号