色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

.Net下的簽名與混淆圖文分析

簽名

即強(qiáng)命名程序集,可以確保你的程序集唯一,而不被篡改、冒用等;即使相同名字的程序集如果簽名也會(huì)不同。

簽名前后程序集結(jié)構(gòu)對(duì)比

簽名前后程序集結(jié)構(gòu)對(duì)比

假設(shè)程序集名子叫"WindowsApplication1",簽名前后程序集信息對(duì)比
復(fù)制代碼 代碼如下:
WindowsApplication1, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
WindowsApplication1, Version=1.0.0.0, Culture=neutral, PublicKeyToken=85377e8b68475fc8

如果項(xiàng)目中引用了一個(gè)已簽名的程序集a.dll,而遭到一偽造的a.dll來偷梁換柱,此時(shí)主程序調(diào)用時(shí)就會(huì)產(chǎn)生異常

未簽名的主程序可以引用已簽名或未簽名的程序集;而已簽名的主程序不能引用未簽名的程序集。

對(duì)程序集強(qiáng)簽名后就有了唯一標(biāo)識(shí),就可以在程序中得知程序集的來路了,可以獲取當(dāng)前執(zhí)行的程序集信息或調(diào)用程序集信息,見:
復(fù)制代碼 代碼如下:
System.Reflection.Assembly.GetExecutingAssembly()
System.Reflection.Assembly.GetCallingAssembly()

如何生成密鑰及簽名,可使用.NET sdk里的sn.exe命令行工具;或者visual studio里的項(xiàng)目--屬性--簽名

密鑰如果有密碼保護(hù),則生成pfx文件,沒有密碼生成snk文件,pfx比snk文件較大些;

混淆

對(duì)編譯生成的MSIL中間代碼進(jìn)行模糊處理,隨著混淆的加重,人腦進(jìn)行多方面智力思維的能力逐漸降低,保護(hù)源代碼以提高反編譯的難度。這種模糊處理并不改變程序執(zhí)行的邏輯。

混淆的工具有很多:如DotFuscator、Obfuscator.NET、 XeonCode、 MaxtoCode

兩者兼并

既對(duì)程序集簽名又做混淆處理也是可以的,而強(qiáng)命名后的程序集如果做混淆會(huì)產(chǎn)生異常,程序也無法正常執(zhí)行。正確的做法的:

延遲簽名 -- 開發(fā)完成 -- 混淆 -- 重新簽名  (即先延遲簽名,混淆后再簽名)

混淆后再簽名,可以使用sn里的R選項(xiàng)完成
復(fù)制代碼 代碼如下:
sn -R a.exe mykey.snk //使用mykey.snk密鑰對(duì)a.exe重新簽名

延遲簽名(重新簽名以前)程序不能運(yùn)行的,如在.NET cf會(huì)報(bào)異常
團(tuán)隊(duì)開發(fā)中不能每個(gè)人都知道私鑰,一般的做法是創(chuàng)建一個(gè)包含公鑰部分的.snk文件。
復(fù)制代碼 代碼如下:
sn - p mykey.snk publicKey.snk

publicKey.snk給開發(fā)人員使用,開發(fā)完發(fā)布時(shí)用mykey.snk重新簽名。

AspNet技術(shù).Net下的簽名與混淆圖文分析,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 年辖:市辖区| 航空| 特克斯县| 绥阳县| 昌都县| 秦皇岛市| 恩施市| 梨树县| 苏尼特右旗| 全椒县| 南城县| 博野县| 甘孜县| 新竹市| 白水县| 河源市| 彰化市| 秦皇岛市| 宣恩县| 安丘市| 西华县| 大渡口区| 揭东县| 福建省| 大埔县| 墨竹工卡县| 舞阳县| 泾川县| 太和县| 陇南市| 五莲县| 页游| 新昌县| 东乌珠穆沁旗| 洪泽县| 龙山县| 丁青县| 九龙县| 合阳县| 沙坪坝区| 志丹县|