在Eclipse中反編譯Class文件完全詳解
Java是開源的,是免費(fèi)的,我們強(qiáng)烈鄙視所有不公開源代碼的東東。比如,對(duì)class文件進(jìn)行加密混淆的類文件,一般情況下,我們是看不到其源代碼的。本文將對(duì)此進(jìn)行詳細(xì)闡述,說(shuō)明如何隨心所欲的反編譯看源碼,體驗(yàn)一下其中的樂(lè)趣。(本文最后面有相關(guān)資源下載)目前在Java開發(fā)工具中,Eclipse可謂是占據(jù)著絕對(duì)的優(yōu)勢(shì),在平常使用中,大家都會(huì)有意無(wú)意的查看一下所調(diào)用JAR包的源代碼,這時(shí)如果沒(méi)有引入源文件的話,將會(huì)看不到結(jié)果。大象以dom4j-

dom4j是開源的,可以在sourceforge.net下載到它的完整版,里面當(dāng)然包含源代碼。大象想說(shuō)的是,在做開發(fā)的時(shí)候,需要用到大量的JAR包,你不可能每個(gè)都去down一個(gè)源碼下來(lái),而且我們用不到這么多的源碼,只是在需要的時(shí)候,看下其中的代碼,解決一時(shí)的問(wèn)題。
大象通過(guò)查看網(wǎng)上其他人的研究成果再結(jié)合自己的分析,總結(jié)了一些經(jīng)驗(yàn),現(xiàn)在整合起來(lái)和大家分享一下。
1、安裝jadclipse插件
選擇插件時(shí),本人曾經(jīng)使用過(guò)網(wǎng)上評(píng)論非常好的Jode開發(fā)的Eclipse插件,不過(guò)效果不是很好,對(duì)有些加密的類不能反編譯,后來(lái)發(fā)現(xiàn)很多人用jadclipse,結(jié)果試驗(yàn)了一下,很不錯(cuò)的說(shuō)。
使用jadclipse插件一定要注意Eclipse版本。jadclipse_
下面來(lái)說(shuō)下安裝過(guò)程,其實(shí)很簡(jiǎn)單,網(wǎng)上也有相關(guān)的資料。將jadclipse插件(版本自己選擇)直接copy到Eclipse目錄中的plugins文件夾下,然后打開Eclipse,選擇"窗口"-"首選項(xiàng)"-"常規(guī)"-"編輯器"-"文件關(guān)聯(lián)",點(diǎn)擊文件關(guān)聯(lián)中的*.class,下面就會(huì)看到"JadClipse Class File Viewer",選中它,點(diǎn)擊缺省值,點(diǎn)擊OK,將它設(shè)置為默認(rèn)的類查看器。如圖:

另外在用jadclipse的時(shí)候,一定要加入jad.exe這個(gè)程序,如果只有插件而沒(méi)有jad,那么還是不能反編譯成功,會(huì)顯示如下所示的錯(cuò)誤,因此我們還要安裝jad。

2、安裝jad
可以在http://www.kpdus.com/jad.html#download 這個(gè)地址下載到最新的jad,而且有不同平臺(tái)的版本,本文后面也有相關(guān)下載。將下載的壓縮包解壓后復(fù)制jad.exe至你的%JAVA_HOME%\bin目錄下,這樣做的好處是使用方便。然后在Eclipse中設(shè)置一下,選擇”窗口”-“首選項(xiàng)”-“Java”-“JadClipse”,在path to decompiler中輸入jad.exe的絕對(duì)路徑。這樣做是為了保證反編譯的效果。大象做過(guò)測(cè)試,只要將jad.exe放入%JAVA_HOME%\bin目錄下,就沒(méi)問(wèn)題了,這個(gè)地方不設(shè)置也沒(méi)關(guān)系,不過(guò)本人還是建議大家設(shè)置一下,其它地方不用管。其實(shí)大象也不知道該怎么弄,就讓它保持默認(rèn)值好了。^_^

到這里,我們的工作就做完了,現(xiàn)在再來(lái)按住Ctrl,用鼠標(biāo)點(diǎn)擊Element,怎么樣?看到源代碼了嗎?貼上部分反編譯代碼,如圖:

使用jad對(duì)絕大部分的加密混淆class文件都能很好的做到反編譯,目前大象還沒(méi)遇到失敗的情況,大家也可以多測(cè)試一下。
現(xiàn)在有人會(huì)說(shuō)了,這樣一個(gè)一個(gè)的看太麻煩了,我需要一次把一個(gè)JAR包下的所有class文件反編譯成java源文件。這樣的想法是可行的,還是使用jad工具。
3、批量反編譯
因?yàn)橹拔覀円呀?jīng)將jad加入到了%JAVA_HOME%\bin中,只要配置了環(huán)境變量,我們就可以在命令行中方便的使用。在這里,大象還是以dom4j-
解壓dom4j-
我解釋一下這些參數(shù)的含義:
-o:覆蓋舊文件,而且不用提示確認(rèn)。
-r:重新加載生成包結(jié)構(gòu)。
-s:定義輸出文件的擴(kuò)展名。jad為默認(rèn)擴(kuò)展名,我們反編譯后當(dāng)然是要.java源文件了。
-d:輸出文件的目錄。src表示反編譯后的所有文件都放在src目錄下。
org/**/*.class:org是解壓后的文件夾的名字,整個(gè)表示org目錄下的所有class文件。你也可以寫成這樣**/*.class,這表示當(dāng)前目錄及其子目錄下所有的class文件(包含所有的子目錄)。
反編譯dom4j-

到此,關(guān)于反編譯的內(nèi)容全部說(shuō)完了,不過(guò)我還想補(bǔ)充一點(diǎn),有可能JAR包中的class文件不是老外的,而是我們自己寫的,里面可能會(huì)有中文的情況,這時(shí),雖然反編譯通過(guò)了,但里面卻是gb2312形式的unicode編碼,因此我們還得做一個(gè)工作,將這些編碼轉(zhuǎn)換成中文。
大象使用ant腳本來(lái)完成這個(gè)工作,內(nèi)容比較簡(jiǎn)單,加了注釋,應(yīng)該很好明白,腳本文件名為build.xml,它放在src目錄下,和反編譯所得的包處在同一層。
<?xml version="1.0" encoding="GBK"?>
<project name="decompile" basedir="." default="native2ascii">
<!-- 定義輸出目錄 -->
<property name="build" value="build"/>
<!-- 清除輸出目錄 -->
<target name="clean">
<delete dir="${build}"/>
</target>
<!-- 創(chuàng)建輸出目錄 -->
<target name="init" depends="clean">
<mkdir dir="${build}"/>
</target>
<!-- 編碼轉(zhuǎn)換 reverse="true"為反向轉(zhuǎn)換 -->
<target name="native2ascii" depends="init">
<native2ascii reverse="true" src="${basedir}" encoding="gb2312" dest="${basedir}/${build}" />
</target>
</project>
有一個(gè)地方需要補(bǔ)充一下,在native2ascii元素中,src和dest這兩個(gè)屬性表示著路徑。如果反編譯后,src目錄下,有多個(gè)不同的文件夾,這時(shí)使用ant來(lái)轉(zhuǎn)換編碼,請(qǐng)先想好要對(duì)哪些文件進(jìn)行反編碼;如果按上面的寫法,將會(huì)把src目錄下的所有文件夾中的所有文件進(jìn)行反編碼。假設(shè),現(xiàn)在有com和org兩個(gè)文件夾(其實(shí)是兩個(gè)包),我只需要對(duì)com中的文件進(jìn)行反編碼,那么可以這樣改寫:src="${basedir}/com"dest="${basedir}/${build}/com"<project name="decompile" basedir="." default="native2ascii">
<!-- 定義輸出目錄 -->
<property name="build" value="build"/>
<!-- 清除輸出目錄 -->
<target name="clean">
<delete dir="${build}"/>
</target>
<!-- 創(chuàng)建輸出目錄 -->
<target name="init" depends="clean">
<mkdir dir="${build}"/>
</target>
<!-- 編碼轉(zhuǎn)換 reverse="true"為反向轉(zhuǎn)換 -->
<target name="native2ascii" depends="init">
<native2ascii reverse="true" src="${basedir}" encoding="gb2312" dest="${basedir}/${build}" />
</target>
</project>
其它的都不變。在cmd中進(jìn)入到src路徑下,輸入ant,回車。可以看到如下結(jié)果:

通過(guò)上面這些操作,class文件已經(jīng)對(duì)我們完全公開,想怎么看就怎么看,呵呵~~~~寫這些,是覺(jué)得對(duì)開發(fā)工作可能會(huì)有一定的幫助,如果看后能夠?qū)δ愎ぷ骰蚴?a onclick="javascript:tagshow(event, '%D1%A7%CF%B0');" href="javascript:;" target="_self">學(xué)習(xí)起到哪怕一點(diǎn)點(diǎn)的作用,大象就感到很滿足了;如果你早就了解這些,或是認(rèn)為寫得不好,還請(qǐng)不要扔磚頭,扔蕃茄,更不要對(duì)大象口誅筆伐,人身攻擊,就當(dāng)看了一篇白話文好了。大家如果有什么好的建議或是意見,歡迎提出來(lái)一起討論,一起學(xué)習(xí)。
本文為菠蘿大象原創(chuàng),如要轉(zhuǎn)載請(qǐng)注明出處。
點(diǎn)擊下載:dom4j-1.6.1.jar jaxen-1.1-beta-7.jar
點(diǎn)擊下載:jadclipse_
點(diǎn)擊下載:jad.exe build.xml
posted on 2009-03-17 14:05 大魚 閱讀(915) 評(píng)論(1) 編輯 收藏 所屬分類: eclipse