强名介绍Strong Name

错误:对程序集“XXX.dll”签名时加密失败   --“读取密钥文件“XXXX.snk”时出错   --   系统找不到指定的文件。 ”

 原因是没有密钥文件,可以使用这样的方法创建一个密钥文件:           1,找到签名工具sn.exe,默认的路径是:系统盘:/Program   Files/Microsoft   Visual   Studio   .NET   2003/SDK/v1.1/Bin;(如果没有的话通过搜索sn.exe来查找)   在命令行下输入sn -k XXXX.snk,将生成的XXXX.snk copy 到项目目录即可

       2. 或者最直接的方法就是,不要签名了,找到XXX项目的AssemblyInfo.cs文件,注释掉下面一行:             [assembly:   AssemblyKeyFileAttribute("..XXX.snk")]             编译就可以通过了。  

强名称为程序集签名 创建密钥对 创建密钥对 要使用强名称为程序集签名,必须具有公钥/私钥对。sn -k sgKey.snk 如果您需要延迟对程序集签名并控制整个密钥对(密钥对不太可能在测试方案之外),可使用以下命令生成密钥对,然后从中将公钥提取到一个单独的文件中。首先,创建密钥对: sn -k keypair.snk 下一步,从密钥对中提取公钥,并将其复制到一个单独的文件中: sn -p keypair.snk public.snk 创建密钥对之后,必须将文件放在强名称签名工具可以找到的位置. 下面简单的解释以下strong   name: 加密签名是计算机安全方面的名词,加密分为对称和非对称加密,这里用的是后者,strong   name是进行程序集版本控制和名称保护的,对一个程序集进行签名后就会得到一个strong   name。strong   name由以下几部分组成程序集的标识(即它的简单文本名称),版本号和区域性信息(如果提供的话),以及公钥和数字签名。strong   name可以确保一个程序集名称的唯一性。强名称是使用相应的私钥,通过程序集文件(包含程序集清单的文件,并因而也包含构成该程序集的所有文件的名称和散列)生成的。需要强调的是,是对程序集的加密和签名(包括名称,版本等信息)得到强名称,强名称是唯一的,所以程序集也是唯一的,程序集加密签名成strong   name需要使用私钥,这个私钥由keyname和keyfile组成,其中KeyName   是指已经安装在计算机上的加密服务提供程序(CSP)中的密钥。KeyFile   是指包含密钥的文件(其实就是.snk文件)。KeyFile通过sn.exe生成。

你可能感兴趣的:(加密,.net,测试,assembly,工具)