花开有时,错过了一日便错过了一季,就象人生错过了相遇,就不再找寻到美丽的相聚
c:\test.snk
然后再编译后运行windowapplication调用class1中的方法就会出错。这里的StrongNameIdentityPermissionAttribute是NET提供的CAS(Code Access Security)中的1个类,具体可参考MSDN,SecurityAction.LinkDemand 是要求直接调用方已被授予了指定的权限,这里即windowapplication要授予了权限才行,如果使用SecurityAction.Demand要求调用堆栈中的所有高级调用方都已被授予了当前权限对象所指定的权限。他们的区别是:如果windowapplication已授权访问,而还有个windowapplication2(未授权访问)通过调用windowapplication中的button1_Click方法来调用class1,这个时候如果使用SecurityAction.LinkDemand就能成功调用,而使用SecurityAction.Demand windowapplication2就不能调用,windowapplication 在这2种情况下都能调用。说到这里大家一定再问PublicKey=后面一串那么长的字符串怎么来。PublicKey后面的字符串是你开始生成的c:\test.snk文件中保存的公钥。那怎么才能看到这个公钥了,照样是用SN.EXE。输入sn -p c:\test.snk c:\publicKey.snk (从 test.snk 中提取公钥并将其存储在 publicKey.snk 中)再输入sn -tp c:\publicKey.snk (显示公钥信息)上面这个命令就能看到PublicKey后面的字符串了,还想什么啊,把那字符串copy下来啊。最后大家一定在关心这个时候windowapplication 要怎么调用class1了,其实也简单,只要把windowapplication 的AssemblyInfo.cs修改为:[assembly: AssemblyKeyFile("c:\\test.snk")]到这里就一切OK了,大家都看到最关键的就是test.snk文件了,所以一定要保护好你自己的test.snk文件。下面是我的代码,大家可以下载看看,在使用的时候记的要把我KEY文件夹下的test.snk copy到c盘。不然会出错^_^。http://files.cnblogs.com/BearsTaR/Solution1.rar
test.snk
publicKey.snk
posted on 2006-05-25 21:04 Bear.sTaR{R} 阅读(4654) 评论(18) 编辑 收藏 网摘 所属分类: FrameWork
不错。不错。我们的系统整好用到了这个方法。 徐汇 回复 引用
使用ildasm 和ilasm反编译之后,去掉publickey 和.permissionset linkcheck 就可以正常引用了. 回复 引用 查看
@margiex 上有政策下有对策嘛. 提高安全性并不能完全保护自己的程序不被破解等等,这个连MS都做不到. 提高安全性只能是提高破解的门槛而已. 如你说的ildasm 反编译情况,也可以使用混淆器来解决这个问题. 回复 引用 查看
签名 回复 引用 查看
听说VS有自带的简单的混淆器咋个启用方法呀? 回复 引用 查看
这个方法很容易破 用ildasm反编译后把头部的强名称删掉再用ilasm编译回去就能用了 回复 引用 查看
方法不错,值得鼓励。MS的ReportingService里面就是这么干的,尽管可以用ILDasm来破解掉单个Assembly,但是当整个系统都采用这个策略的时候,全部破解很费精力。 回复 引用
@GouGou 等下写篇简单的文章介绍下VS自带的混淆器用法。 回复 引用 查看
@枫之物语 兄弟可以看看我3楼的回复!!! 回复 引用 查看
@GouGou 使用VS自带的混淆器防止你的程序被反编译 http://bearstar.cnblogs.com/archive/2006/05/26/dotfuscator.html 回复 引用 查看
似乎在.net2.0中,这个办法会失效的! 加了StrongNameIdentityPermissionAttribute的类没有得到保护,其他程序直接调用也没有异常产生。 回复 引用
@volcanodeng 2.0中没试过,不知道是不是有所改变。 回复 引用 查看
在.net2.0中好像真的不能用这个,有别的方法解决吗 回复 引用
很多混淆工具都是没用的哦 嘿嘿 回复 引用 查看
@.NET菜鸟磊磊 看了MSDN2005中写的代码也和我的差不多的,试过了不知道为什么不行。 你可以自己去看下: ms-help://MS.MSDNQTR.v80.en/MS.MSDN.v80/MS.NETDEVFX.v20.en/cpref11/html/T_System_Security_Permissions_StrongNameIdentityPermission.htm#codeExampleToggle 回复 引用 查看
哈…… 1、CAS在完全受信环境是不会检查权限的。 2、反编译再编译回去就好了, 方法不错,值得鼓励。MS的ReportingService里面就是这么干的,尽管可以用ILDasm来破解掉单个Assembly,但是当整个系统都采用这个策略的时候,全部破解很费精力。 不懂就别乱说, 程序员都是会写脚本的,不都像你样…… 回复 引用 查看
大哥!!你用的是VS2005吗!! 能不能发一份测试的给我! 博客上提供的下载地址,下不到! 我的Email:yaochutao@139.com. 谢谢了,很急用!!!! 我根据你的方法!但没出现想要的效果!! 回复 引用
请给我一份源代码 谢谢maidini@163.com 回复 引用
Powered by: 博客园 Copyright © Bear.sTaR{R}