文档章节

Oolong反编译

 李念阳
发布于 2017/02/17 13:58
字数 846
阅读 12
收藏 0
点赞 0
评论 0

如何分析JAVA字节码--Oolong反编译,有需要的朋友可以参考下。

处于C和机器语言之间有一种叫汇编语言,它很接近机器语言,却又可以使人可以看得懂这些指令,C语言的编译器会先将代码翻译成汇编,然后再翻译成机器语言。

其实对于java,刚开始接触也有些迷惑,就以为它是一个很NB的语言,可以一次编译随处执行。但其实很久之前就有人跟我说过,“java的跨平台是依赖编译器自身的”,当时还不是很理解这句话的含义,如今看来,所谓“跨平台”的特性,基本都要归功于java虚拟机。换句话说,某平台下没有java虚拟机,java就无所谓跨平台。

很容易理解,语言无法做到跨平台因为编译器就依赖平台,在不同的环境上,对编译器而言他会将代码翻译成不同的目标语句,使得该二进制码可以在该平台上被正常执行。同样可以想到,如果要做到“一定程度的”跨平台,就必须要有一个中间翻译器,这就是JVM。首先jvm接受统一格式的java字节码,同时适配各种操作系统,能够将该java字节码翻译成该平台下的目标代码,使得该代码能够被系统执行。

java字节码就是JVM世界里的机器语言,而JVM如何运行这些字节码的呢?是否与机器语言一样有一些类似汇编的指令集呢?答案是肯定的。

JVM有一套自己的指令集,当然该指令集不随系统、CPU等改变而改变,该指令集是帮助JVM识别一个java字节码的。现在介绍一种是用Oolong工具将java字节码翻译为类汇编语言Oolong的方法。

首先需要下载Oolong,当然这个挺麻烦的,如果有需要可以到我的github上下载源码。https://github.com/jpbirdy/programming-for-the-jvm

当然,实际只需要一个编译好的jar包就可以了,这里可以下载到http://pan.baidu.com/s/1i39UgV7,下载后将Oolong.jar放到jdk的lib目录下,同时添加环境变量的CLASSPATH,添加一条Oolong.jar的路径地址。

然后就可以使用Oolong进行class的反编译了。过程如下

假设存在一个HelloWorld.class文件,在class目录中执行:

 

java COM.sootNsmoke.oolong.Gnoloo HelloWorld.class


在该目录下会产生一个HelloWorld.j文件,用文本编辑器打开该文件可以看到如下内容:

 

 

.source HelloWorld.java
.class public super jpbirdy/HelloWorld
.super java/lang/Object
.method public <init> ()V
.limit stack 1
.limit locals 1
.var 0 is this Ljpbirdy/HelloWorld; from l0 to l5
.line 6
l0:    aload_0
l1:    invokespecial java/lang/Object/<init> ()V
l4:    return

.end method

.method public static main ([Ljava/lang/String;)V
.limit stack 2
.limit locals 1
.var 0 is args [Ljava/lang/String; from l0 to l9
.line 10
l0:    getstatic java/lang/System/out Ljava/io/PrintStream;
l3:    ldc "Hello World!"
l5:    invokevirtual java/io/PrintStream/println (Ljava/lang/String;)V
.line 11
l8:    return

.end method

b

以上就是一个简单的System.out.println("HelloWorld")的汇编代码。

 

介绍该工具主要可以通过将java代码转变为类汇编代码,去解释一些JVM级别控制的一些问题,例如i++是否线程安全等等。

© 著作权归作者所有

共有 人打赏支持
粉丝 0
博文 9
码字总数 12426
作品 0
济南
Oolong and Gnoloo

Oolong:一种汇编语言, .j文件可以编译成.class文件 Oo long乌狼 Oolong is closer to the JVM class file format than Java (1)directive(指示) (2)instruction(Oolong指令) What is Oolong ......

Oscarfff
2016/07/21
14
0
如何分析JAVA字节码--Oolong反编译

处于C和机器语言之间有一种叫汇编语言,它很接近机器语言,却又可以使人可以看得懂这些指令,C语言的编译器会先将代码翻译成汇编,然后再翻译成机器语言。 其实对于Java,刚开始接触也有些迷...

城固如春
2016/11/15
55
0
iOS游戏开发开源库总结

游戏将在以后一直是软件行业的发展方向,在appstore上,游戏占了很大的比例。我也是游戏出生,总结一下自己用过的开源游戏引擎,接2D与3D分类。 2D: cocos2d 3D: isGL 3D Galaxy Game Engine...

长平狐
2012/08/13
93
0
常用iOS游戏开发工具与SDK

常用iOS游戏开发工具与SDK2D游戏开发框架cocos2d-iPhone,iOS平台最流行的开源2D游戏引擎,包含两个较大的版本:0.9x和2.x,其中0.9x支持OpenGL ES,2.x支持OpenGL ES 2.0。Objective-C编写,...

Durian_2012
2014/01/16
0
0
Android APK反编译详解(附图)(转)

原文转自:http://blog.csdn.net/ithomer/article/details/6727581 这段时间在学Android应用开发,在想既然是用Java开发的应该很好反编译从而得到源代码吧,google了一下,确实很简单,以下是...

巴顿
2015/01/16
0
0
Eclipse下的Java反编译插件 查看源代码不再困难

Eclipse下的Java反编译插件:Eclipse Class Decompiler,整合了目前最好的2个Java反编译工具Jad和JD-Core,并且和Eclipse Class Viewer无缝集成,能够很方便的使用本插件查看类库源码,以及采...

DavidBao
2015/05/20
0
0
Android APK反编译详解(附图)

这段时间在学Android应用开发,在想既然是用Java开发的应该很好反编译从而得到源代码吧,google了一下,确实很简单,以下是我的实践过程。 在此郑重声明,贴出来的目的不是为了去破解人家的软...

长平狐
2013/01/06
121
0
android apk反编译详解

这段时间在学Android应用开发,在想既然是用Java开发的应该很好反编译从而得到源代码吧,google了一下,确实很简单,以下是我的实践过程。 在此郑重声明,贴出来的目的不是为了去破解人家的软...

刘小米
2014/10/30
0
0
eclipse安装JAVA反编译插件

前言:在实际的开发中几乎都会使用到一些框架来辅助项目的开发工作,对于一些框架的代码我们总怀有一些好奇之心,想一探究竟,有源码当然更好了,对于有些JAR包中的代码我们就需要利用反编译...

Zero零_度
2016/12/27
45
0
Android反编译(一) 之反编译JAVA源码

Android反编译(一) 之反编译JAVA源码 [目录] 1、工具 2、反编译步骤 3、实例 4、装X技巧 1、工具 1).dex反编译JAR工具 dex2jar http://code.google.com/p/dex2jar/downloads/list 2).JAVA反编...

老鹰a
06/29
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

CVE-2013-0077 堆溢出分析

找了很久才发现这个环境比较容易搭建分析... 环境: 系统---Win XP SP3 漏洞程序:QQPlayer 3.7.892.400 出错DLL:quartz.dll 6.5.2600.5512 调试工具:x32db+gflag.exe 过程: 首先gflag设置...

Explorer0
11分钟前
1
0
python上传文件

//注意 <form action="/login/" method="post" enctype="multipart/form-data"> f=request.FILES.get('fafa') ff=open(f.name,mode='wb') for i in f.chunks(): ff.write(i) ff.close()......

南桥北木
23分钟前
0
0
CISCO VPN Client Reason 442 WIN8/10错误解决方案

http://jdkleo.iteye.com/blog/2163493 引用 http://my.oschina.net/cloudcoder/blog/220391?p={{currentPage 1}} 在使用cisco VPN 客户端登录时,产生Reason 442:Failedto enable Virtual......

chenfj_fer
27分钟前
0
0
信号量有没有容量限制?

之前一直误以为信号量初始化的时候那个初始化的值是信号量的“容量”,昨天同事指出了我的错误,最初我是不相信的,经过以下代码实践,证明了我的错误: Java版: import java.util.concurr...

锟斤拷烫烫烫
31分钟前
0
0
【RocketMQ】Message存储笔记

概述 消息中间件存储分为三种,一是保存在内存中,速度快但会因为系统宕机等因素造成消息丢失;二是保存在内存中,同时定时将消息写入DB中,好处是持久化消息,如何读写DB是MQ的瓶颈;三是内...

SaintTinyBoy
42分钟前
0
0
Android应用Context详解及源码解析

Android应用Context详解及源码解析 本文定位:优质文章收集 本文转载 1 背景 今天突然想起之前在上家公司(做TV与BOX盒子)时有好几个人问过我关于Android的Context到底是啥的问题,所以就马...

lichuangnk
今天
0
0
PostgreSQL的昨天今天和明天

PostgreSQL 是一种非常复杂的对象-关系型数据库管理系统(ORDBMS), 也是目前功能最强大,特性最丰富和最复杂的自由软件数据库系统。有些特性甚至连商业数据库都不具备。 这个起源于伯克利(...

闻术苑
今天
1
0
Mysql对自增主键ID进行重新排序

1,删除原有主键: ALTER TABLE `table_name` DROP `id`; 2,添加新主键字段: ALTER TABLE `table_name` ADD `id` MEDIUMINT( 8 ) NOT NULL FIRST; 3,设置新主键: ALTER TABLE `table_nam......

niithub
今天
0
0
福利篇:免费csdn vip账号分享

分享一个发布免费csdn vip账号的网站:啰嗦vip www.lostvip.com , 各种软件开发类的视频教程:慕课网、动脑学院、黑马各大培训机构VIP视频教程,非常不错!

在水一方发盐人
今天
1
0
Nginx+Tomcat搭建高性能负载均衡集群

一、 工具   nginx-1.8.0   apache-tomcat-6.0.33 二、 目标   实现高性能负载均衡的Tomcat集群:    三、 步骤   1、首先下载Nginx,要下载稳定版:      2、然后解压两个Tom...

码代码的小司机
今天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部