国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > 綜合 > 正文

使用SNK密鑰文件保護你的DLL和代碼不被反編譯教程

2024-07-21 02:04:44
字體:
供稿:網(wǎng)友

大家做項目開發(fā)一般都是分層的,比如UI層,業(yè)務(wù)層,數(shù)據(jù)訪問層。業(yè)務(wù)層引用數(shù)據(jù)訪問層的DLL(比如dataAccess.dll),并使用dataAccess.dll中的方法。當項目完成并給客戶用了,可有些心里BT的客戶這個時候也可以請個稍微懂NET的人來引用你的dataAccess.dll并調(diào)用其中的方法搞破壞。比如可以直接使用里面的ChangePwd(string UserName,string Pwd)方法把其他用戶的密碼改了,這個時候就你就.......
好了,該開始說怎么保護我們的代碼了:

首先我們需要把我們的程序集做成強命名的程序集。

這里我們在.NET 命令提示中輸入sn -k c:/test.snk 創(chuàng)建一個新的隨機密鑰對并將其存儲在 c:/test.snk 中

然后新建立類庫ClassLibrary1,里面只有個類文件Class1.cs,代碼如下:
代碼如下:
using System;
namespace ClassLibrary1
{
public class Class1
{
public Class1()
{
//
// TODO: 在此處添加構(gòu)造函數(shù)邏輯
//
}
 
public string Insert()
{
return "ok";
}
}
}

AssemblyInfo.cs代碼:
//............其他的就用默認
[assembly: AssemblyKeyFile("c://test.snk")] // 連接上面用強命名工具SN.exe生成的文件.

接著創(chuàng)建個WindowApplication來調(diào)用我們的ClassLibrary1,代碼:
代碼如下:
private void button1_Click(object sender, System.EventArgs e)
{
MessageBox.Show(new ClassLibrary1.Class1().Insert());
}

不修改WindowApplication的AssemblyInfo.cs。
在這里就可以直接運行了,不過大家都看的出來,這樣是能成功調(diào)用Class1中的方法的。

現(xiàn)在讓我們來修改下Class1.cs,代碼:
代碼如下:
using System;
using System.Security.Permissions;
 
 
namespace ClassLibrary1
{
[StrongNameIdentityPermissionAttribute(SecurityAction.LinkDemand, PublicKey =
"00240000048000009400000006020000002400005253413100040000010001000551684edd1600"+
"8ccbdd337b1cf1490490d97fe0048c5f3629cc4f5104578499eace9b2a94115022edd620def472"+
"8b4f088291cfa77a40659afba611fdafbb7894b93a64049d439936bd0cd8dc0704625aeb735892"+
"e9eb3f910a49a2925af10515d935654d7adac5567ff6d780d23d587de0ff4d271da7b30680fa88"+
"a47a4ba4")]
public class Class1
{
public Class1()
{
//
// TODO: 在此處添加構(gòu)造函數(shù)邏輯
//
}
 
public string Insert()
{
return "ok";
}
}
}

然后再編譯后運行windowapplication調(diào)用class1中的方法就會出錯。

這里的StrongNameIdentityPermissionAttribute是NET提供的CAS(Code Access Security)中的1個類,具體可參考MSDN,SecurityAction.LinkDemand 是要求直接調(diào)用方已被授予了指定的權(quán)限,這里即windowapplication要授予了權(quán)限才行,如果使用SecurityAction.Demand要求調(diào)用堆棧中的所有高級調(diào)用方都已被授予了當前權(quán)限對象所指定的權(quán)限。他們的區(qū)別是:如果windowapplication已授權(quán)訪問,而還有個windowapplication2(未授權(quán)訪問)通過調(diào)用windowapplication中的button1_Click方法來調(diào)用class1,這個時候如果使用SecurityAction.LinkDemand就能成功調(diào)用,而使用SecurityAction.Demand windowapplication2就不能調(diào)用,windowapplication 在這2種情況下都能調(diào)用。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 贞丰县| 乌兰县| 铁力市| 九龙县| 延川县| 新安县| 沙湾县| 乌鲁木齐县| 张家港市| 泌阳县| 衡阳县| 通州市| 东阳市| 富锦市| 双桥区| 东乡县| 藁城市| 沐川县| 赣州市| 革吉县| 桐城市| 榆林市| 翼城县| 隆尧县| 惠州市| 甘肃省| 平乡县| 巍山| 黄骅市| 兴安盟| 离岛区| 会东县| 罗江县| 罗定市| 通化市| 吴堡县| 山丹县| 平阴县| 九江县| 阿城市| 天津市|