强名称程序集(strong name assembly)——为程序集赋予强名称

本文介绍了强名称程序集如何解决程序集唯一标识、防仿冒和篡改等问题,并详细阐述了如何利用强名称签名及全局程序集缓存(GAC)实现程序集的安全部署。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >




         引言

                 在曾经的项目开发中,在程序集中见到过一个后缀为*.snk的文件。当时看这个文件的图标。感觉可能是企业内部保护版权啥的一种方式。



  一,强程序集攻克了哪些问题?


1,唯一标识一个程序集

2,放置程序集被仿冒和被篡改。

3,能够部署到全局程序集缓存(GAC:GlobalAssembly Cache)中;在将强名称程序集不熟在GAC其中以后,强名称程序集也能够称为共享程序集(shared assembly



二,强名称与GAC

        

强名称:

定义了一个规则,不单单以文件名称来区分程序集,这个规则就是强名称。

 

GAC

定义一个特殊的目录,这个目录能够识别这样的规则。而且同意文件名称同样的文件存在,这个特殊的目录就是GAC


三,为程序集赋予强名称


         打开VS 开发者命令提示工具:





              首先,我们来创建公钥私钥文件。使用 sn -k命令:


             


         然后我们会发如今此目录下创建LHC.snk成功:


           

须要注意的地方:

1。每次调用sn时候,创建的私钥/密钥对文件都不同样,不仅自己的计算机每次生成的不同,其它全部计算机生成的也不同样。

2。关于这个文件的命名。假设是个人。能够以自己的名字命名。假设是团队。。组织火公司,能够以组织名称来命名。

3,在大多数情况下,个人和组织仅仅须要一个snk文件就能够了。以后创建强名称的时候,都使用这个snk文件。因为会使用snk文件的私钥对强名称程序集进行签名,因此这个文件必须严密保护。

 

上面创建的LHC.snk里面既包括公钥。也包括私钥。

公钥能够使用sn.exe查看。可是私钥无法查看。




    假设须要查看公钥的话。能够使用 sn -p命令:


    


      之后使用sn -tp命令查看*.pk文件:


     




     创建好这个公钥私钥文件之后,我们就能够使用它来标识程序集的唯一性了。



     在须要设置的程序集中,为此程序集设置签名属性:





        



       保存之后再观察此程序集,会发现多出来一个文件:



      







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值