日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

.Net下的签名与混淆

發布時間:2025/3/19 asp.net 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 .Net下的签名与混淆 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

任何時候,軟件安全與版權保護都是很重要的,特別是企業級開發或一些特殊應用方面。對.NET平臺下的開發如何做到安全,本文主要討論簽名與混淆和原理與思路。

簽名

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

簽名前后程序集結構對比

假設程序集名子叫"WindowsApplication1",簽名前后程序集信息對比

WindowsApplication1, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
WindowsApplication1, Version=1.0.0.0, Culture=neutral, PublicKeyToken=85377e8b68475fc8

?

如果項目中引用了一個已簽名的程序集a.dll,而遭到一偽造的a.dll來偷梁換柱,此時主程序調用時就會產生異常

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

對程序集強簽名后就有了唯一標識,就可以在程序中得知程序集的來路了,可以獲取當前執行的程序集信息或調用程序集信息,見:

System.Reflection.Assembly.GetExecutingAssembly()

System.Reflection.Assembly.GetCallingAssembly()


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

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

混淆

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

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

兩者兼并

既對程序集簽名又做混淆處理也是可以的,而強命名后的程序集如果做混淆會產生異常,程序也無法正常執行。正確的做法的:

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

混淆后再簽名,可以使用sn里的R選項完成

sn -R a.exe mykey.snk //使用mykey.snk密鑰對a.exe重新簽名


延遲簽名(重新簽名以前)程序不能運行的,如在.net cf會報異常

團隊開發中不能每個人都知道私鑰,一般的做法是創建一個包含公鑰部分的.snk文件。

sn - p mykey.snk publicKey.snk


publicKey.snk給開發人員使用,開發完發布時用mykey.snk重新簽名。

轉載于:https://www.cnblogs.com/develop/p/3543894.html

總結

以上是生活随笔為你收集整理的.Net下的签名与混淆的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。