當前位置:編程學習大全網 - 源碼下載 - c#源碼怎麽加密啊?

c#源碼怎麽加密啊?

c# dll 加密最快的方法使用加殼工具Virbox Protector,直接加密,Virbox Protectorke可以對dll進行性能分析,分析每個函數的調用次數,對每個函數選擇保護方式如:混淆/虛擬化/碎片化/代碼加密等;每種加密方法的特點是什麽呢?

代碼加密(X86):

針對X86匯編代碼:壹種代碼自修改技術(SMC)保護代碼。把當前代碼加密存儲為密文,存儲起來,當程序運行到被保護函數時候自動解密並且執行,執行之後再擦除代碼,運行到哪裏才解密哪裏的代碼,黑客無法獲得原始機器指令和內存完整性的代碼,由於是純內存操作所以運行速度快, 性價高的保護手段,建議全加

代碼加密(IL)

針對dotNet程序,保護IL代碼:壹種動態運行方法解密被保護代碼。把當前代碼加密存儲為密文,存儲起來,當程序運行到被保護函數時候自動解密並且執行,執行之後再擦除代碼,執行之後再擦除代碼,運行到哪裏才解密哪裏的代碼,黑客無法獲得原始的中間語言的指令和內存完整性的代碼,由於是純內存操作所以運行速度快, 性價高的保護手段,建議全加

壓縮

類似zip等壓縮軟件把代碼和數據段壓縮,由於帶有動態密碼,沒有任何工具可以自動脫殼,是防止反編譯和反匯編關鍵手段。

代碼混淆(IL):

將代碼中的各種元素,如變量,函數,類的名字改寫成無意義的名字。比如改寫成單個字母,或是簡短的無意義字母組合,甚至改寫成“__”這樣的符號,使得閱讀的人無法根據名字猜測其用途。

a)重寫代碼中的部分邏輯,將其變成功能上等價,但是更難理解的形式。比如將for循環改寫成while循環,將循環改寫成遞歸,精簡中間變量,等等。

b) 打亂代碼的格式。比如刪除空格,將多行代碼擠到壹行中,或者將壹行代碼斷成多行等等。

c) 添加花指令,通過特殊構造的指令來使得反匯編器出錯,進而幹擾反編譯工作的進行。

代碼混淆器也會帶來壹些問題。主要的問題包括:· 被混淆的代碼難於理解,因此調試除錯也變得困難起來。開發人員通常需要保留原始的未混淆的代碼用於調試。· 對於支持反射的語言,代碼混淆有可能與反射發生沖突。· 代碼混淆並不能真正阻止反向工程,只能增大其難度。因此,對於對安全性要求很高的場合,僅僅使用代碼混淆並不能保證源代碼的安全。

代碼混淆的特點是安全度低、不會影響效率。

代碼虛擬化:

針對X86代碼: 是指將機器代碼翻譯為機器和人都無法識別的壹串偽代碼字節流;在具體執行時再對這些偽代碼進行壹壹翻譯解釋,逐步還原為原始代碼並執行。 這段用於翻譯偽代碼並負責具體執行的子程序就叫作虛擬機VM(好似壹個抽象的CPU)。它以壹個函數的形式存在,函數的參數就是字節碼的內存地址。 由於虛擬機代碼和虛擬機CPU的實現可以做到每次都是隨機設計和隨機執行 並且代碼每次可以隨機變化,包括壹些邏輯上的等價變化可以參考硬件N個與非門NOT-AND實現各種邏輯門,算法和訪問內存形式的變化,包括數學上的非等價變化,代碼體積幾乎可以膨脹達到100到10000倍,造成機器無法做算法還原到原有邏輯。

代碼虛擬化的特點是:安全度中、不會影響效率。

代碼碎片化:

深思自主知識產權的最新技術:基於 LLVM 和 ARM 虛擬機技術,自動抽取海量代碼移入 SS 內核態模塊,極大的降低了使用門檻, 不再需要手動移植算法,可移植的算法從有限的幾個增長到幾乎無限多,支持的語言也不再限於 C, 這是加密技術的壹次綜合應用,效果上類似於將軟件打散執行,讓破解者無從下手。

安全度高、建議關鍵函數或調用加密鎖方法;使用太多會影響效率

  • 上一篇:狗身上有很多小紅包。原因是什麽?!!
  • 下一篇:“張同學”首次直播帶貨,數據卻很差,這是什麽原因造成的呢?
  • copyright 2024編程學習大全網