强名介绍Strong Name

9 篇文章 0 订阅

错误:对程序集“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生成。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值