加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

未能加载文件或程序集“xxx”或它的某一个依赖项。强名称验证失

发布时间:2020-12-14 01:07:30 所属栏目:百科 来源:网络整理
导读:当我们从互联网上下载一个程序集供本地调用的时候,如何保证这个程序集是 未经第三方恶意篡改 过的呢?如果两个程序集的名称、大

当我们从互联网上下载一个程序集供本地调用的时候,如何保证这个程序集是未经第三方恶意篡改过的呢?如果两个程序集的名称、大小、版本号都相同是不是就意味着这两个程序集文件就相同了呢?在.NET平台下区分程序集采用的方法是使用名称,但是名称有强弱之分。

强名称在弱名称的基础上添加了数字签名,并且强名称签名的程序集不能引用未被签名的程序集

强名称的作用主要有三个:一是区分不同的程序集;二是确保代码没有被篡改过;三是在.NET中,只有强名称签名的程序集才能放到全局程序集缓存中。

一、问题背景

在使用 vs 开发过程中,.Net程序集的dll与exe使用了签名(仅延时签名


并且为了开发方便,执行了忽略强名称验证的命令(xxx 为签名的程序集名称):

sn.exe -Vr xxx

但是执行代码调试时,仍然出现了错误(publicKey为: e982c879116440581,根据实际情况会不同):

二、解决方法

实际上为了开发方便,执行禁用.Net程序集强名称验证的操作(sn.exe -Vr xxx),会在注册表中添加对应的注册项,具体位置如下:

  • x86:
[HKEY_LOCAL_MACHINESOFTWAREMicrosoftStrongNameVerification
  • x64:
[HKEY_LOCAL_MACHINESOFTWAREMicrosoftStrongNameVerification]
[HKEY_LOCAL_MACHINESOFTWAREWow6432NodeMicrosoftStrongNameVerification]

查看实际的位置时,发现Wow6432Node注册项下确实有(我的是x64位系统):

但根本就没有HKEY_LOCAL_MACHINESOFTWAREMicrosoftStrongNameVerification 这个注册项,而我的应用程序是x64的,需要使用该注册项来验证.Net程序集的强命名。

所以采用手动建立该注册项,并添加响应的注册项到该目录下。为了简单,直接建立了*,e982c879116440581 注册项。(如果添加 “*”,将禁用所有的.Net程序集强名称验证)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读