Android编程之还原JD-GUI反编译后代码

jd-gui这款jar反编译软件,大家经常用到,它反编译后的代码可以重新生成java文件。但它反编译出的代码,在遇到部分java特定语句的时候就不容易被看懂了。

我这里就jd-gui反编译后代码的复原内容讲讲我的经验,与大家分享一下:


1、switch语句:

正常的switch语句:

 public boolean onTouchEvent(MotionEvent event) {
  final int y = (int) event.getY();
  mBounceHack = false;
  switch (event.getAction()) {
  case MotionEvent.ACTION_UP:
   if (!isVerticalScrollBarEnabled()) {
    setVerticalScrollBarEnabled(true);
   }
   if (getFirstVisiblePosition() == 0 && mRefreshState != REFRESHING) {
    if ((mRefreshView.getBottom() >= mRefreshViewHeight || mRefreshView
      .getTop() >= 0) && mRefreshState == RELEASE_TO_REFRESH) {
     mRefreshState = REFRESHING
     prepareForRefresh();
     onRefresh();
    } else if (mRefreshView.getBottom() < mRefreshViewHeight
      || mRefreshView.getTop() <= 0) {
     resetHeader();
     setSelection(1);
    }
   }
   break;
  case MotionEvent.ACTION_DOWN:
   mLastMotionY = y;
   break;
  case MotionEvent.ACTION_MOVE:
   applyHeaderPadding(event);
   break;  case MotionEvent.ACTION_CANCEL:
   break;
  }
  return super.onTouchEvent(event);
 }


经过JD-GUI反编译后:

public boolean onTouchEvent(MotionEvent paramMotionEvent) {
		int i = (int) paramMotionEvent.getY();
		this.mBounceHack = 0;
		switch (paramMotionEvent.getAction()) {
		default:
		case 1:
		case 0:
		case 2:
		}
		while (true) {
			return super.onTouchEvent(paramMotionEvent);
			if (!isVerticalScrollBarEnabled())
				setVerticalScrollBarEnabled(1);
			if ((getFirstVisiblePosition() != 0) || (this.mRefreshState == 4))
				continue;
			int j = this.mRefreshView.getBottom();
			int k = this.mRefreshViewHeight;
			if (((j >= k) || (this.mRefreshView.getTop() >= 0))
					&& (this.mRefreshState == 3)) {
				this.mRefreshState = 4;
				prepareForRefresh();
				onRefresh();
				continue;
			}
			int m = this.mRefreshView.getBottom();
			int n = this.mRefreshViewHeight;
			if ((m >= n) && (this.mRefreshView.getTop() > 0))
				continue;
			resetHeader();
			setSelection(1);
			continue;
			this.mLastMotionY = i;
			continue;
			applyHeaderPadding(paramMotionEvent);
		}
	}

一、可以看到,反编译后的switch部分有了很大的变化,case部分都被打乱了。但这里还是有规律可循的,也就是说case部分的排列顺序是不会变的,如上例中case部分就是按照原来的保持不变。

二、接下来看while循环部分。这里面就包含了本该分别在case中的部分代码。首选将最开始的return取去,直接放到代码的最后面。然后看从return开始到第一个continue,这个就是第一个case中的代码部分,从第一个continue到第二个continue就是第二个case中的代码,以此类推。


注意:如果在这期间包含了if部分,里面的continue是不能作数的,要找最外层部分的continue。

上面的截图中可以看出,有的if部分中也会代有continue,但它是不能算做标识位的。关于if部分拆解,下面会有具体讲到。


2、if语句


  • 9
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
### 回答1: jd-gui是一款常用的Java反编译工具,它可以将Java程序的class字节码文件反编译Java代码。然而,在使用jd-gui进行反编译后,可能出现中文乱码的情况。 这是因为Java程序中的字符串常量在编译的时候会被转换为Unicode编码,而在反编译过程中,jd-gui默认对这些字符串常量进行Unicode码的还原,因此在反编译结果中,中文字符可能会出现乱码。 为了解决这个问题,我们可以在jd-gui的菜单栏中选择“File--Settings--Display”,将“Decompiler--Decompile Type”选项设置为“UTF-8”,这样就可以正确地显示中文字符了。 另外,我们还可以使用其他的反编译工具,如Procyon、Fernflower等,这些工具在反编译中文字符时表现更加稳定、准确。同时,我们在编写Java程序时,也可以尽可能使用UTF-8编码,来避免中文字符的乱码问题。 ### 回答2: jd-gui是一款非常常用的Java反编译工具,用于反编译Java字节码文件。然而,在使用jd-gui反编译Java字节码文件时,可能会出现中文乱码的情况。 这是因为Java编译器在编译Java代码时,会将中文字符转换成Unicode编码,而jd-gui反编译Java字节码文件时,会将这些Unicode编码转换成原来的中文字符。但是,因为编译时使用的编码和反编译时使用的编码不同,可能会导致转换出现错误,进而导致中文字符乱码。 为了解决这个问题,可以将Java代码文件的编码与反编译后的字节码文件的编码设置为一致。比如,可以将Java代码文件的编码设置为UTF-8,然后在jd-gui中将字节码文件的编码也设置为UTF-8,就可以避免中文乱码的问题。 同时,也建议在Java代码中尽量避免使用中文字符,尽量使用英文或者Unicode编码来表示,这样可以有效地避免中文乱码的问题。 ### 回答3: JD-GUI是一个Java字节码反编译工具,它可以将Java程序的class文件反编译成易于阅读和修改的Java代码。然而,在使用JD-GUI反编译后,我们可能会发现一些中文字符会显示为乱码。这是因为在Java编译器编译过程中,中文字符会被编译成Unicode编码,在反编译后需要进行解码才能正确显示中文。 要解决这个问题,我们可以通过编辑JD-GUI的配置文件来改变默认的编码方式。具体的做法是,在JD-GUI的主面板中,点击“Options”按钮,然后选择“Preferences”菜单。在弹出的对话框中,选择“Decompiler”选项卡,然后将“Default charset”选项改为“GBK”或者“UTF-8”,以便正确解码中文字符。 如果修改了配置文件后还是无法正确显示中文,还可以尝试使用其他反编译工具,例如Procyon、Fernflower等,这些工具通常具有更好的对中文字符的支持。不过需要注意的是,在进行Java程序开发时,最好使用英文字符命名变量和类名,以避免因为字符编码问题带来的不必要麻烦。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值