吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 10177|回复: 30
上一主题 下一主题
收起左侧

[原创] Windows逆向分析入门(二)——原理篇

  [复制链接]
跳转到指定楼层
楼主
KongKong20 发表于 2020-6-22 10:57 回帖奖励
本帖最后由 KongKong20 于 2020-6-23 10:28 编辑

前言
  正向开发,是先写代码,再编译成软件。而逆向分析,到手的只有软件。从软件入手,推测对应的代码,需要了解一下编译之后的软件是怎么跑起来的。

软件运行过程
  1、软件加载到内存。
  2、CPU读取内存的指令。
  3、根据指令,再读取数据,进行运算。
  4、运算的过程,数据是存在CPU里面的寄存器。
  5、运算过程,用到另一个功能,需要保存当前环境,存到堆栈。
  (这里涉及操作系统和计算组成原理,大概了解,心里有底就好)

代码语言的变化
  1、C/C++语言:高级语言,给人看的
  2、汇编语言   :低级语言,给机器用的
  (逆向分析,接触多是汇编语言, 需要自行学习下)

软件加载过程
  磁盘 >>内存>>寄存器
  1、代码编译成软件,先放在磁盘(C盘,D盘这些)
  2、开始运行的时候,就会加载进内存(平时说的内存条)
  3、真正运行的是在CPU(也就是所谓的芯片),里面存数据的地方叫寄存器。

软件的构成
  软件的外部
    包含:一个主要程序(exe后缀),多个独立库(dll后缀)。
    内存一开始加载exe,有必要的时候,exe再把dll加载进内存来。
    exe或者dll在内存的开始位置,叫做基址。(每次加载,随机放置,基址不固定)
    exe或者dll里面和基址的距离,叫做偏移。(每次加载,内部不变,偏移固定)
     
    打个比喻:exe和dll相当小尺子,要放在内存这个大尺子上。
    大尺子上只要有空位,小尺子就可以随便放。
    小尺子不管怎么放,里面的刻度固定的。
    
    
  软件的内部
    软件 = 代码 + 数据
    数据 = 静态数据 (数据不会变)+ 动态数据 (数据会改变)
    动态数据 =  全局数据 (多个函数共用)+ 局部数据(单个函数私有)

    代码和静态数据在软件运行过程不会改变,位置固定,可以方便使用。
    全局数据,因为是共用的,位置固定,也可以方便使用。
    所以这三种的偏移是不变的。

       内存地址 =  基址 + 偏移。
    基址可以用GetModuleHandle得知。
    偏移又是不变的,内存地址也就可以算出来了

    而偏移会变化的局部数据,就不能直接算出来了。
    局部数据,是软件运行过程中,临时生成又销毁的。
    所以要获取局部数据,只能在软件的运行过程进行拦截。(也就是所谓的HOOK)

逆向分析目的
  逆向分析的两个目的
    1、调用功能
    2、获取数据

  通过上面的原理可以知道
    1、调用功能
      代码是固定的,找到偏移,就可以调用。
    2、获取数据
      对于全局数据,找到偏移,就可以得到。
      对于局部数据,需要拦截,才可以得到
      (拦截的是代码,所以要找代码的偏移)

  所以,逆向的核心点,是找固定的偏移。

下一篇,找偏移的方法。

参考资料(下功夫,基础扎实,逆向才顺手)
汇编:http://c.biancheng.net/asm/
反汇编:《C++反汇编与逆向分析技术揭秘》
函数调用:https://blog.csdn.net/zhongguoren666/article/details/7586074?utm_source=blogxgwz6

免费评分

参与人数 20吾爱币 +18 热心值 +17 收起 理由
平静_悠扬 + 1 + 1 我很赞同!
lm222 + 1 + 1 尺子的比喻太棒了
JohnusYang + 1 谢谢@Thanks!
pxxkm + 1 + 1 我很赞同!
tigerssj + 1 我很赞同!
xx1990 + 1 + 1 这是高手
风中找感觉 + 1 + 1 谢谢@Thanks!
jeanytonic + 1 + 1 呆萌新人,正是需要这样的文章,谢谢
macolma + 1 谢谢@Thanks!
小兔一样的小白 + 1 + 1 我很赞同!
2595453382 + 1 用心讨论,共获提升!
Snprszy + 1 + 1 期待楼主大作。
musicer03 + 1 用心讨论,共获提升!
dglbl + 1 + 1 热心回复!
china-ray + 1 + 1 用心讨论,共获提升!
雾满拦江 + 2 + 1 用心讨论,共获提升!
媚眼的丹客 + 1 + 1 用心讨论,共获提升!
lrv + 1 + 1 苦尽甘来,赠人玫瑰手留余香!
朱朱你堕落了 + 1 期待楼主大作。
smilingk + 1 + 1 用心讨论,共获提升!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

推荐
Hmily 发表于 2020-6-23 09:55
KongKong20 发表于 2020-6-23 09:50
连文章怎么写,都要管?对你来说是短,对别人不一定。

如果文章段落都这样拆分成一堆帖子,那版块都会占满了,影响阅读其他文章,就跟软件更新一个版本号发一个帖子一样,为了刷帖子数和阅读量就使劲更新版本号一个道理,虽然只是软件区明令禁止这种行为,技术区没做要求,但还是应该共同优化这种问题,作为管理确实要管,另外图片的问题也得处理一下。
沙发
慵懒丶L先森 发表于 2020-6-22 11:29
3#
 楼主| KongKong20 发表于 2020-6-22 11:53 |楼主
慵懒丶L先森 发表于 2020-6-22 11:29
通俗易懂,支持!期待更多的干货

参考资料可以先自行了解下,后续会用上的
4#
L__ 发表于 2020-6-22 13:07
通俗易懂,期待更多的干货,支持并点赞
5#
china-ray 发表于 2020-6-22 13:37
大白话看明白了,感谢!
6#
musicer03 发表于 2020-6-22 14:15
新的逆向教程越来越少了
7#
Snprszy 发表于 2020-6-22 15:44
通俗易懂,支持!期待更多的干货~
8#
薛定谔消失的弦 发表于 2020-6-23 00:36
这是32位汇编内容?
9#
刀大喵 发表于 2020-6-23 08:06
讲的很好 小白福利 支持楼主
10#
Hmily 发表于 2020-6-23 09:31
@KongKong20 图片盗链无法显示,上传本地,另外你这些文章都很短,就别分那么多帖子了,合并成一个,分成段落就行了。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-12-25 23:03

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表