·您的位置: 首页 » 资源教程 » 编程开发 » ASP.NET » .NET中的强名称机制

.NET中的强名称机制

类别: ASP.NET教程  评论数:0 总得分:0
一个程序集包括四个区分彼此的属性:

l 文件名(不包括扩展)

l 版本号

l 文化标识

l 公钥标识

现在让我们来看看一个比较常见的强名称程序集:

l Name= MSCorLib

l Version=1.0.3300.0

l Culture=neutral

l PublicKeyToken=b77a5c561934e089

如果我们自己编写一个弱名称程序集,那么通常PublicKeyToken这一项就没有。

下面我尝试着说一说强名称的机制。

首先,你通过SN.exe获得一个公钥和一个密钥。

然后,使用公钥对程序集的可执行文件(不包括DOS头、PE头等)进行哈希算法,得到一个文件散列值。

最后,使用密钥对文件散列值进行加密,得到一个密文。

这样,最后的强名称程序集里面要三样东西:

l 公钥标识(公钥的散列值的最后八个字节)

l 公钥

l 密文

使用公钥和程序集的可执行文件(不包括DOS头、PE头等)进行哈希算法可以得到一个文件散列值,使用公钥和密文也可以得到一个文件散列值,如果这两个散列值完全一致,OK,验证通过。

最后,说说公钥标识(公钥的散列值的最后八个字节)的作用:

l 区分程序集,上面提到过它是程序集区分彼此的四大属性之一

l 验证公钥

总的来说,强名称机制最起码起到两个作用:

l 区分程序集

l 避免程序集被恶意更改





-= 资 源 教 程 =-
文 章 搜 索
关键词:
类型:
范围:
纯粹空间 softpure.com
Copyright © 2006-2008 暖阳制作 版权所有
QQ: 15242663 (拒绝闲聊)  Email: faisun@sina.com
 纯粹空间 - 韩国酷站|酷站欣赏|教程大全|资源下载|免费博客|美女壁纸|设计素材|技术论坛   Valid XHTML 1.0 Transitional
百度搜索 谷歌搜索 Alexa搜索 | 粤ICP备19116064号-1