一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

WPF與混淆器

時至今日,混淆依然是.NET程序的一道重要保護手段,而混淆器對WPF應用程序的支持是怎樣的呢?我們今天就通過實例講解一下。

首先建立如下圖所示的簡單的用戶界面:

在界面代碼中設置一些綁定屬性:

在后臺代碼中首先定義一個種族枚舉,以便于在列表中使用:

下面在窗體Window1類中定義以下屬性:

紅圈處的代碼功能是將種族枚舉的全部值載入到種族列表屬性中,這樣就可以在前后臺一直以統一、優雅的方式使用枚舉,這是個不錯的小技巧。

接下來在構造函數中直接硬編碼一些屬性的值,然后將自己作為自己的DataContext

玩魔獸的朋友們請勿喧嘩….

現在編譯并運行程序,可以看到數據被很好地反映到了界面上:

OK,接下來就是主角了,我們將以Dotfuscator Professional Edition 4.3 Evaluation為例來進行介紹。

打開Dotfuscator后直接新建項目,載入我們編譯好的程序,然后直接進行混淆和輸出,運行輸出后的程序:

嗯,什么數據都沒顯示出來,為什么呢?

據我的理解就是,混淆器目前還沒法解析及修改XAML文件,致使混淆后的后臺代碼與前臺XAML界面描述不匹配,比如“{Binding 種族}”之類的語句根本無法與混淆后的代碼關聯,所以就全部都無法顯示。

以下顯示了部分混淆的映射結果:

其中灰色底色的項代表已被從程序中移除,其他的都有對應的混淆后的名稱。

現在,要使混淆后的程序正常工作,我們就必須向XAML妥協。

你可能首先想到的是恢復上面被刪除的那幾個與界面相關的屬性,但是我嘗試過,那并不起作用。

而只要禁止對Window1類的混淆,問題就基本上解決了:

看看混淆的結果,大概能猜想出Dotfuscator是自動將禁止混淆的類的公共屬性也加入到排除混淆行列的,那幾個屬性這次沒有被移除:

但我仍無法解釋為什么當只禁止混淆屬性、不禁止混淆類時程序仍舊無法正常工作。

現在還有個問題,就是列表上顯示的是混淆后的枚舉名稱,這很好處理,只要禁止混淆枚舉的所有字段就好了:

現在程序已完全恢復正常了,但是這與未經混淆的程序也沒有太大分別了,看看通過Reflector解析的混淆后的程序:

總結:混淆技術原本已經算是比較完善了,而現在,WPF又為之帶來了新的挑戰,我們只能期待各廠商能夠盡快跟進,讓WPF程序也能受到全面的保護,為其未來的廣泛應用奠定基石。

本文的PDF版本下載:http://www.box.NET/shared/abeeolbk72

源代碼下載:http://www.box.NET/shared/uqadhnhsua

NET技術WPF與混淆器,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 色精品一区二区三区 | 国产一级一级一级成人毛片 | 五月开心六月伊人色婷婷 | 国产精视频 | 天天拍拍天天爽免费视频 | 国产伦久视频免费观看 视频 | 久久综合九色综合欧洲 | www.午夜| 色综合色综合色综合色综合 | 国产在线观看一区 | 精品久久久99大香线蕉 | 亚洲天堂成人在线观看 | 在线色资源 | 在线永久免费观看黄网站 | 九九热亚洲精品综合视频 | 黄视频在线观看www 黄视频在线观看免费 | 日本乱人伦在线观看免费 | 成人看的午夜免费毛片 | 99久久精品费精品国产 | 成人激情站 | 九九视频精品在线 | 亚洲一区二区影视 | 国产第一页久久亚洲欧美国产 | 久996视频精品免费观看 | 午夜免费视频 | 国产精品亚洲欧美一级久久精品 | 香蕉成人999视频 | 亚洲福利在线播放 | 成人免费观看完整视频 | 欧美变态老妇重口与另类 | 精品国产第一国产综合精品 | 久久精品国内一区二区三区 | 亚洲一区二区三区久久精品 | 国产婷婷色一区二区三区深爱网 | 91大神精品长腿在线观看网站 | 国产精品视频免费 | 一本久道久综合久久鬼色 | 欧美在线视频网站 | 美女一级ba大片免色无遮住 | 国产午夜亚洲精品不卡福利 | 国产精品精品视频 |