UPX壳,手脱后打不开,可能是在windows10脱壳的缘故吧。放在XP虚拟机上手脱可能会好,但是提示缺少dll。无奈,智能用工具了。

用的这个,感觉蛮好用的。

先打开程序。随便输入一个数,提示error

IDA中找到相应字符串。

F5反编译

可以看到,在while循环里面,限制我们输入的字符串必须是L或者R。当时我就输入了19个L,结果提示了error。按照代码的逻辑来看,讲道理是不可能出现这种情况的。

后来想可能是这个sub_41114F函数有问题,但是当我在IDA中查看时,出现了下面的情况。

这个问题不清楚,于是改用OD。进入这个函数查看。

首先调用了call 004110A5,这个函数结束后,后面的汇编代码会发生改变。如下图。

进入IDA来看看call 004110A5函数,如下图

这几个Virtual函数查了百度,并不是太明白。不过结合OD的调试,和IDA反编译的结果,可以推测出具体作用是:从某个地址开始,对每个字节进行异或4运算。一共有0x40个字节被改变。

这个推测可以在OD中得到验证。图中框出来的就是被改变了的,一共0x40个字节。这里也许就可以解释为何在IDA中反编译失败了,因为没有经过这个函数动态变化后的代码是错误的,因此无法反编译导致错误。

分析上图汇编代码,容易得到,对输入的字符串中偶数位的进行异或,奇数位不变。

然后输入LHLHLHLHLHLHLHLHLHL,异或后即十九个L(这里我没注意,后面写脚本的时候以为是LR交替的,导致浪费了很多时间)。放进去跑一跑试试。

提示得到了303755。这里的话,结合题目mountain climbing想一想,还有就是L和R,一个左一个右。推测应该是输入LR组合,让这个数达到最大值。

回到IDA查看。

由rand函数获得随机值,

然后放入423D78中。最后输出的值就是423D78了。写脚本跑出来就行了。以IDA反编译的源码为基础,稍微改一改就ok了。

#include <stdlib.h>
#include <iostream>
using namespace std;
int main()
{ int i,j;
int Sum=;
int v7=;
int v5=;
int v3=;
string flag;
srand(0xc); //rand函数包含在stdlib头文件中
int Array[];
for ( i = ; i <= ; ++i )
{
for (j = ; j <= i; ++j )
{
Array[ * i + j] = rand() % ;
}
}
Sum+=Array[];
while(v3<) //判断哪个大,哪个大就加哪个
{
if(Array[ * (v7+) + v5]>Array[ * (v7+) + v5 + ])
{
flag+="L";
Sum += Array[ * ++v7 + v5];
}
else
{
flag+="R";
Sum += Array[ * ++v7 + ++v5];
}
v3++;
}
for(i=;i<flag.length();i++) if(i%==) flag[i]=flag[i]^; //异或处理
cout << flag;
return ;
}

最新文章

  1. 读书笔记--SQL必知必会02--检索数据
  2. C语言实现四则运算
  3. Wix 安装部署教程(十五) --CustomAction的七种用法
  4. [转]shell基本算术运算
  5. angularjs 不同的controller之间值的传递
  6. Leetcode Largest Number c++ solution
  7. css tricks
  8. Linux 统计文件夹下文件个数
  9. HBase笔记--filter的使用
  10. javascript 验证身份证
  11. java后台开发- NOTE
  12. 采用proguard困惑android代码
  13. Python的基础学习(第二周)
  14. servlet中的request和response
  15. Shiro的FormAuthenticationFilter登陆成功不跳转
  16. Linux 入门视频教程
  17. RxSwift之路 1#Swift语法知识准备
  18. angularjs 的模型无法绑定到隐藏域(input hidden)
  19. 搭建Vue2+Vuex+Webpack+Pug(jade)+Stylus环境
  20. mysql 设置外键 四大属性 CASCADE SET NULL NO ACTION RESTRICT 理解

热门文章

  1. centos 7 + Net Core 3.0 + Docker 配置说明(不含https)
  2. 前端知识体系:JavaScript基础-原型和原型链-理解JavaScript的执行上下文栈,可以应用堆栈信息快速定位问题
  3. modbus_百度经验
  4. Kafka集群---分布式消息系统
  5. Educational Codeforces Round 33 (Rated for Div. 2) A题
  6. luogu 2519 [HAOI2011]problem a 动态规划+树状数组
  7. bbs项目---表关系
  8. Linux 网络通信命令之 netstat
  9. Ubuntu切换登录用户和root用户
  10. CF985C