鱼C论坛

 找回密码
 立即注册
查看: 9324|回复: 9

[软件安全] 【进阶】《逆向工程核心原理》

[复制链接]
发表于 2016-11-12 17:22:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
61ozEQObhvL.jpg

) X9 i7 W. X- l# {
( P4 U9 N1 v; @6 @9 ~: J书名:《逆向工程核心原理》
5 V6 G& u$ ?' _0 F7 \作者:李承远) n& v3 Y! i. z5 A) S$ J0 }7 j
译者:武传海3 h2 M9 e2 |4 z4 j3 K. B
出版社:人民邮电出版社
' @# Z: S! r$ ]; O出版年:2014年5月1日(第1版)
' K. D- |$ |0 K6 j/ p$ h& D2 K8 n4 y定价:109.00元
% _8 t; K* q+ X6 }8 `% x* W装帧:平装
$ O+ m! o: y0 s0 KISBN:9787115350183
* d7 Q! A- G2 R4 g7 Q1 u+ q: [+ U$ \0 T
购买链接:& D$ i9 I6 t' L, b$ T2 f
( Q4 F) D; S! }+ z2 B2 j- u; R


3 [9 Z8 n" Z- |, I亚马逊 -> 传送门% s/ N" M5 u5 M  {9 F0 k/ s

7 B# t- `, |1 z* [; a7 B/ _当当网 -> 传送门) E7 N1 q4 Q9 n8 f* o) G
) q# y/ k" A/ @, ]
京东 -> 传送门
& o7 i& B7 d" z9 I( \3 b0 S& m
- c6 U/ z- K% A) u' h天猫 -> 传送门! {; _* J& @: {' W
7 M5 p" T8 G# p  F% J+ D9 \& G

; G5 R' T7 f4 Q8 K& g, I内容简介:  }" x1 o6 p! l) C

0 i1 t7 L! w% s6 |9 B, O4 P

0 {! U/ S3 S) J1 h《逆向工程核心原理》十分详尽地介绍了代码逆向分析的核心原理。作者在 Ahnlab 研究所工作多年,书中不仅包括其以此经验为基础亲自编写的大量代码,还包含了逆向工程研究人员必须了解的各种技术和技巧。彻底理解并切实掌握逆向工程这门技术,就能在众多 IT 相关领域进行拓展运用,这本《逆向工程核心原理》就是通向逆向工程大门的捷径。) @* L3 C2 t" u6 S& [$ f' v; M; c

9 Y$ n* X: f( R) `* y想成为逆向工程研究员的读者或正在从事逆向开发工作的开发人员一定会通过《逆向工程核心原理》获得很大帮助。同时,想成为安全领域专家的人也可从《逆向工程核心原理》轻松起步。6 B/ x& _) m3 l9 S) X5 n5 |
8 n% {$ c7 [6 R. v) C$ M
) A6 i- ]6 p. t! `: Y; D
目录:* {6 Z/ W4 t; J2 X$ L

8 c- i9 I0 T. Q) v$ f
+ e0 C4 Y3 H$ R8 H. H4 B
第一部分 代码逆向技术基础" n0 L" Y( Z7 Y) [$ O3 o

9 ?- Q9 F+ A7 Y$ o第1章 关于逆向工程 8 T' D# g! q" ]3 o8 ?- D
2 o# |4 }1 |# G8 |1 f6 a# _
1.1逆向工程 - x  q' x+ @0 C3 D9 }% |& a
1.2代码逆向工程
% s  y$ _/ ~5 [" O- k" }7 k1.2.1逆向分析法
* O+ R0 L! U( n$ f1.2.2源代码、十六进制代码、汇编代码 ' T9 x9 _- i6 S& K7 {) s
1.2.3“打补丁”与“破解”
3 J6 H: r6 K/ h7 X; z1.3代码逆向准备
% Z( h* ]: l0 [0 g3 h8 Y1.3.1目标 % a; b" O- A* a  c, E0 \. G+ y
1.3.2激情 ! G% c+ t: O2 e7 j3 N/ I! T- J% L
1.3.3谷歌
. e( A' e- j5 V1.4学习逆向分析技术的禁忌
( I- z2 U1 S3 }: e4 L, f1.4.1贪心
4 r0 {* T( M: U1.4.2急躁
8 W. y# t% Z4 m$ C' \# ^" n; ]1.5逆向分析技术的乐趣
; b) x% L, _3 f
! @1 p- g  d. ?3 \& M5 l( d; H第2章 逆向分析HelloWorld!程序 4 W/ N1 w. Z2 K* h; u* ?
' |1 B% d2 K# r( k" r
2.1HelloWorld!程序
- q( D2 w& T; ]% O/ o, _% \2.2调试HelloWorld.exe程序 ; A( q* U( U2 m: C2 v4 ~% j
2.2.1调试目标 3 B6 o8 z3 i, o% b" D% x
2.2.2开始调试
9 ]3 A( E1 |2 g8 ^2.2.3入口点
& y; w% T: t. K- k2.2.4跟踪40270C函数 # t! l# {5 B1 A4 e+ W
2.2.5跟踪40104F跳转语句
0 I3 P/ o  [  w' L2.2.6查找main()函数
3 n. s+ k! g1 {, A  K0 Y! _( u, P2.3进一步熟悉调试器
, \/ |. B" T# f- l$ J2.3.1调试器指令 ) z# _6 ]' N. Z' [
2.3.2“大本营” : E% ^6 C" B; V2 C/ R5 n
2.3.3设置“大本营”的四种方法 2 J% Y1 I  ^  I
2.4快速查找指定代码的四种方法 9 D( c0 |. _1 A; _- S' A6 p, _
2.4.1代码执行法
4 b: R  Z# c" Q# X" u! y2.4.2字符串检索法
; q6 t; t" Z3 u) a+ t: d2.4.3API检索法(1):在调用代码中设置断点
6 ~/ ?# a" [0 e' D/ @* c8 _! E  Y2.4.4API检索法(2):在API代码中设置断点 , w2 \& h  |+ {3 y& `
2.5使用“打补丁”方式修改“HelloWorld!”字符串 % h% ~# X8 k3 L4 ^" p: ?5 O5 s
2.5.1“打补丁”
8 y7 K! Z% s" E) w1 V, C% C2.5.2修改字符串的两种方法 " g7 O+ T8 s; b2 R% C% w. N
2.6小结 1 N: @* |8 r6 a. U& P- z, d
3 J. U# x/ K% Y0 o, r  e3 j, c
第3章 小端序标记法 $ o  {. T) p- H
+ D" Q/ R) x, G3 q
3.1字节序 6 J9 V9 K7 b' J+ p. H0 Z/ ]
3.1.1大端序与小端序 # t; C1 B, f1 U9 B
3.1.2在OllyDbg中查看小端序
! S& [5 t% \7 I  |8 M8 h: s  ]( f5 V$ J- W1 Q3 @+ t
第4章 IA—32寄存器基本讲解
3 e) C! s# t5 H- L' n' c0 ~1 o
6 c$ c1 N. _" p3 T4 G9 L% l4.1什么是CPU寄存器
3 t( W1 [3 n" _9 I- o: {4.2IA—32寄存器 % [' r* Q: F: L  ^; z
4.3小结
# J% f' z* X- B* ]; n/ ^  Z
0 J+ @- @3 t+ n/ H' n1 ?第5章栈6 }+ G0 j; E7 Z. L1 \

1 i6 G7 E  h9 g+ t5.1栈 ( S  G4 ~2 R3 c8 c3 C
5.1.1栈的特征
0 m0 @+ M1 {+ C: O5.1.2栈操作示例 ' H! g4 `( p( }
& I- Q8 Y9 R- h% o! N
第6章 分析abex'crackme#1$ |: K2 K* @2 ^& z
) }, f4 C4 Z; P7 \) P$ `
6.1dbex'crackme#1
; r) f3 m4 D. ~; Y7 T( m* |6.1.1开始调试
1 \1 C& G( L/ S: Y% P6.1.2分析代码
. q4 s: Z( x1 [. _3 D" ~4 e6.2破解 0 i3 O9 q9 k) z& B
6.3将参数压入栈
- @- Y9 E+ F; V/ w$ M0 v0 f6.4小结
  ]; y9 o3 {/ G: {
6 ^5 I! P8 K4 @) f第7章 栈帧
; V3 k- O+ v* v2 [
! V. X, o, x% P8 I: [( b' l7.1栈帧
/ o  Y( {% t5 d4 o% C2 x* z7.2调试示例:stackframe.exe
1 {# H" u% u( `7.2.1StackFrame.cpp
2 q7 ~- `! ?# x, X' A  @# V7.2.2开始执行main()函数&生成栈帧 * s& |* @# @6 A$ ~3 N4 q
7.2.3设置局部变量
* F! {9 r2 C+ g+ {, D7.2.4add()函数参数传递与调用
0 }# S* |; i( r6 R7.2.5开始执行add()函数&生成栈帧
% M/ c- n3 E+ o' m( Z* w6 }7.2.6设置add()函数的局部变量(x,y)
$ \6 `3 e5 E- R* j- H1 `7.2.7ADD运算 ( Q( {$ u7 ?$ M, x# @
7.2.8删除函数add()的栈帧&函数执行完毕(返回)   d, H& F$ l- Z9 x: E, w
7.2.9从栈中删除函数add()的参数(整理栈) 9 O) G7 F' o& v4 j9 B* L
7.2.10调用printf()函数 9 v, S0 x) o# z8 n; {5 t3 ^+ ~
7.2.11设置返回值
* Y) D3 y( g( {5 w# e7.2.12删除栈帧&main()函数终止 3 ^9 T6 C( d) D: L
7.3设置OllyDbg选项
! h  J( K3 d. ]/ v+ f% V7.3.1Disasm选项
1 w* B" m2 _# n3 O7.3.2Analysisl选项
% j2 q+ B  s6 ?, ~  B7.4小结 6 f4 n. _; d3 p* }

) _5 _) a& d9 V( j+ c2 t$ X第8章 abex'crackme#2   i$ R0 k# L5 e: u5 v/ V3 P

% Q* ?+ s) }9 y: Y$ h0 ?0 w8.1运行abex'crackme#2
5 `$ r: Y, W1 m2 ^: y8.2VisualBasic文件的特征
0 }# s: X' ?) x  h+ l* @8 S. o9 @8.2.1VB专用引擎
/ `8 c/ l% d5 u% ]. j) T3 @/ B8.2.2本地代码和伪代码
1 P! t) j2 O' n7 N7 |8 y- f8.2.3事件处理程序
9 {- K3 J9 @) U- m9 n: [8.2.4未文档化的结构体 : @$ A6 `) u4 J9 }
8.3开始调试 , ]9 V4 N! l7 k
8.3.1间接调用 ' D. y/ k# _% }5 x  E7 J/ m
8.3.2RTMainStruct结构体
+ F9 k, x: O. ], A! }2 b8.3.3ThunRTMain()函数 & N% b0 g/ P0 }% D( g7 q
8.4分析crackme 5 H7 U5 s, g6 h4 {/ i
8.4.1检索字符串 , e1 i3 ^; L( E0 E4 B0 X2 F( p
8.4.2查找字符串地址 % p" K7 d0 p9 P/ T5 |" C' a$ h6 J
8.4.3生成Serial的算法
) x& x( p+ v& R0 d; \/ i2 h8 Z( _8.4.4预测代码
( ]6 g9 L9 Q! V+ p, L8.4.5读取Name字符串的代码
0 ^5 C* R0 c: G2 E0 R8.4.6加密循环 8 U* T. z3 m5 A/ Q
8.4.7加密方法
8 W: a; A8 [( C3 j8.5小结 7 b& V  c9 K. P% v$ E& \$ Q
  {' r+ y5 [9 y  q
第9章 ProcessExplorer——最优秀的进程管理工具 8 X' z$ t/ y% C; U' z& i* O
+ x9 m8 c  G1 L3 e1 S2 W
9.1ProcessExplOrer
* D! W' q: h$ j( [+ G  O" m9.2具体有哪些优点呢 ( a/ i- v9 y- P1 Y) R
9.3sysintemals& ]) `6 O1 ~  P- ~8 }- S4 l
  x8 S0 p+ `! _7 Q- ~$ V9 }" A3 ^% M
第10章 函数调用约定
+ H* U) b5 `6 Y' W
  g6 `- j7 j, _0 {10.1函数调用约定 " T8 e  p; A- t8 p8 ?& B% @
10.1.1Cdecl
* }* V. ^3 |/ n6 }! H+ y10.1.2Stdcall ) c7 ~" j) U- a5 O: E
10.1.3faStCall
% Z3 }. P6 D+ S, X. N! C- u. A3 G. D2 U% T( o7 A
第11章 视频讲座
: p7 H! ^& k5 E3 c& y: _5 V! {4 W' U% [+ }  ]6 A0 b* `
11.1运行
6 m" K. z* R4 R: l9 @* M0 \% Q11.2分析
+ L$ _  J' z) }" x9 a: _9 [11.2.1目标(1):去除消息框
8 r) f+ j: I) M3 I11.2.2打补丁(1):去除消息框
* X/ e& v8 X" c% w2 V& {  K. q( H11.2.3目标(2):查找注册码
% V+ J( U5 h" G9 c1 S11.3小结
) n- p# B+ z! r$ c5 a- r8 R& D
! z& d' h, l9 E0 }" g5 `第12章 究竟应当如何学习代码逆向分析
( E# m1 }8 f2 j" E% b& W, M6 ?# d# ?  f# B  f
12.1逆向工程
/ G9 N3 g3 G6 i1 I3 T12.1.1任何学习都应当有目标
/ v/ k" C0 ~+ ^: E& n( w! O12.1.2拥有积极心态
& C9 b! C- [7 ^$ {+ _0 Q  J12.1.3要感受其中的乐趣 & e* t9 Q. \* d2 R
12.1.4让检索成为日常生活的一部分
% ?7 J2 }0 g1 c3 `$ N12.1.5最重要的是实践
4 l# Q5 Y+ ^+ Q4 m4 l9 @  d12.1.6请保持平和的心态: u5 F/ M4 U* }2 _

$ O. h; G  h1 u/ ?, D8 D- Q# |8 G第二部分 PE文件格式 / O: ?% Z5 f' t6 [2 j  u2 H6 h8 ~

& h6 j; c0 I( P; y第13章 PE文件格式: I% @, G8 T( v7 y% Y

& S8 d* U( Q& |/ C% g! G, k! x5 ?5 o13.1介绍
6 ?! g0 f, Y6 U# o13.2PE文件格式 - Y# O$ O  X. h! C6 o* `' q. m
13.2.1基本结构
9 S% E* S+ h) V4 D/ P2 x13.2.2VA&RVA 7 k( ]7 e& N+ S  k: ]
13.3PE头 8 U( S* D/ O* @& G
13.3.1DOS头
5 w5 w+ ?6 M1 p$ I* U% C: H% E' o+ ]13.3.2DOS存根
) y7 E9 \# {! J13.3.3NT头 # E; E9 {/ f' y5 s  V1 c9 t. [
13.3.4NT头:文件头
( N/ J( O# u3 q, t13.3.5NT头:可选头 6 m) ^  o: A! o  c/ q; ^
13.3.6节区头
/ f/ d: l! |. U5 M13.4RVAtoRAW
/ q6 H( I# n, w! Q1 {13.5IAT
7 [$ f: r  @  b9 F/ Q13.5.1DLL 7 F% ^. A3 i# R5 G8 j
13.5.2IMAGE_IMPORT_DESCRIPTOR
' p6 _5 t8 P/ T" T4 S7 P13.5.3使用notepad.exe练习
) T& C  ]1 c: W2 l/ M7 a! Z9 D13.6EAT
! ^4 _4 U# i# ^1 s. h13.6.1IMAGE_EXPORT_DIRECTORY
, y# C( J9 E! N, T13.6.2使用keme132.dll练习 5 u8 @8 L# M) p' d1 Y7 a' v
13.7高级PE
) E5 D4 V$ q) Q3 O) n3 J: ?* G+ q" a% S13.7.1PEview.exe
% w1 z: l9 |1 H1 f& `0 v13.7.2PatChedPE
; J, V7 U3 x* @9 U13.8小结8 @$ e6 w% @% C$ _6 B. g% \. `7 t, e& `

6 @; r5 Z/ J: X4 }& @1 l第14章 运行时压缩
  D; ^/ {: f1 H' h) c0 M- T+ g0 H9 L. x% k7 a
14.1数据压缩
" g1 j. @  O* Y# \14.1.1无损压缩 , p) Y8 t( p# D; C6 m% k
14.1.2有损压缩
/ V4 [4 a% V& ?% ^14.2运行时压缩器 , ]+ |7 P: v/ n7 {4 w
14.2.1压缩器 1 I7 D! |# Q6 j+ v! g
14.2.2保护器   o. M& P8 V. V% e$ |6 K; H5 c
14.3运行时压缩测试 0 }6 @% Q# h1 w6 b4 Z
: a* O1 X: p0 Z/ b; S
第15章 调试UPX压缩的notepad程序
3 \( r* c! B4 ?5 Y9 j! x9 ^' d+ C
( u) t4 F+ S3 T4 C! c, T9 ^15.1notepad.exe的EP代码 0 z* ~" Q5 |; B: f3 k6 O
15.2notepad_upx.exe的EP代码   m$ i8 E2 I# b+ h) I
15.3跟踪UPX文件 + M+ j4 e# c6 _! P2 |3 g) I  }: g/ B$ S
15.3.10llyDbg的跟踪命令 & o! H* w2 W, k1 T" Q# S* s  N6 O  \" |) z
15.3.2循环#1
; a( U) M& C$ }" y9 p15.3.3循环#2 ' Y& n8 c# E9 n0 d3 {
15.3.4循环#3
$ z- g' ?% Q, P% z1 G* y15.3.5循环#4 4 q, L; U5 Y' A3 J
15.4快速查找UPXOEP的方法 3 Y; Y5 L: }& B- j
15.4.1在POPAD指令后的JMP指令处设置断点 5 G0 d0 `4 J' h1 Y2 g5 H8 ^
15.4.2在栈中设置硬件断点
! f) P3 P# J+ f0 x4 r' b4 |  O3 W) e) |15.5小结
, @2 p- [- j, ~% n, w6 {# l+ y! |, _0 N
第16章 基址重定位表
  \/ N/ G6 @  S& a
' I" S- E; Z& a1 Q16.1PE重定位
' l0 }' R6 [1 H; v4 F" V16.1.1DLI/SYS " ^% |, r; `2 Y+ B4 |9 ]% Z
16.1.2EXE
4 V! l" Q3 ]/ P9 _' P" J16.2PE重定位时执行的操作 , R- j4 s1 p3 O- r
16.3PE重定位操作原理 2 P; \& M5 C3 j2 a* H
16.3.1基址重定位表 8 M2 ^2 ]8 ~, e% ]) D7 N
16.3.2IMAGE_BASE_RELOCATION结构体
5 X' ^3 Q/ U. S- o" W2 j16.3.3基址重定位表的分析方法 # K$ T0 _# o2 {! v+ F+ S: Q
16.3.4练习9 W4 Z: P, B  L( N
: `. l& r, B, C* Q: y
第17章 从可执行文件中删除.reloc节区
  C+ o" l$ U5 Y( g / [% R% V" K  p5 N7 F4 z' ?- T# B: Z
17.1.reloc节区 4 {. U7 v0 _' }0 D" N
17.2reloc.exe
/ W. `! C' J: F' ?17.2.1删除.reloc节区头
5 a) z% V6 G7 t: G1 C1 M+ D17.2.2删除.reloc节区 3 }- H+ H+ k5 D1 L0 ^
17.2.3修改IMAGE_FILE_HEADER
+ c7 t! }# T0 T& Q17.2.4修改IMAGE_OPTIONAL_HEADER 5 l' W/ F8 y4 I0 ?
17.3小结
/ g0 s3 C  `' r, n* j9 P
7 b, H4 r) B3 a第18章 UPackPE文件头详细分析
+ A, P+ k# D- E+ ?0 O# `
- v) n- l0 I. ]18.1UPack说明
1 K7 F( f) C" |7 G" c0 q- K1 D18.2使用UPack压缩not印ad.exe 6 d% G" [- T4 _$ E/ y3 E* T
18.3使用StudPE工具
2 b- j% @8 _$ p! n+ L4 w# ], B18.4比较PE文件头 8 q6 _& T/ K9 A7 q1 S; b4 L
18.4.1原notepad.exe的PE文件头
& }0 Q5 s3 G  G# [2 M6 \18.4.2notepad_upack.exe运行时压缩的PE文件头 3 R8 k4 I' P- p
18.5分析UPack的PE文件头 ; c9 |8 p! v: B" ?. |9 p
18.5.1重叠文件头
" r# {+ ?* s7 U3 R# ~5 q) l( }18.5.2IMAGE_FILE_HEADER.Size Of Optional Header
5 f: V; ^6 R' b" Q- i2 w& d18.5.3IMAGE_OPTIONAL_HEADER.Number Of—Rva And Sizes ( ~* l: V5 o% i* q1 h- g: L
18.5.4IMAGE_SECTION_HEADER 3 i. h# B  J1 Z8 e
18.5.5重叠节区 , D+ ~* v/ {' g: S) u  O: k. k
18.5.6RVA to RAW # m" C7 A: D  k& c" }' A! [$ ]
18.5.7导入表(IMAGE_IMPORT_DESCRIPTORarray)
3 ^. Z' G' a5 O. Y: u18.5.8导入地址表
3 k( \1 \, y  |6 a18.6小结
# Q# Y9 X8 f2 ^" X! e. K
  j- X/ k8 M, o, N. g3 b第19章 UPack调试—查找OEP
2 R! s/ R' l! D" B/ h2 p3 ~" X- p# n% `7 o* S  U1 D; P5 p0 q
19.1ollyDbg运行错误
$ d, L. v1 z: p8 G( x/ N( \5 v, V19.2解码循环
3 B9 L; C+ S9 W+ ]( T, ?) k19.3设置IAT : F! Y4 G9 z5 w+ B8 C% n9 T
19.4小结
0 F8 I5 P$ U8 K* d 0 S( o( _% ^) ^! Q+ a7 \( U
第20章 “内嵌补丁”练习( |- ^; X2 P% F9 H9 u& `

: F( i& ~& d5 v' f% Z20.1内嵌补丁
7 |4 d' @+ M3 r9 H2 g20.2练习:Patchme " |' O! v, j1 o/ b# T% u0 w3 A. {
20.3调试:查看代码流 ; q1 M0 J9 O1 e% k
20.4代码结构 ' w9 h$ e. D; ^4 P7 b6 w3 u5 Z
20.5“内嵌补丁”练习 9 l( j# ]) Z  Z. j
20.5.1补丁代码要设置在何处呢
" D& Y. ^# [, d20.5.2制作补丁代码 2 }+ {+ i& _+ g& ?5 r
20.5.3执行补丁代码
* @7 h; A* \9 i  z20.5.4结果确认
5 J8 X/ C/ d0 e) x6 u 8 x& ?3 _* X6 V) f+ a6 e
第三部分DLL注入8 I+ |& X# Z: O9 v0 D; [6 V

# N0 h% k, t- J" V. K* f5 `第21章 Windows消息钩取* M2 _8 ?* B5 H# I' A4 S
2 R+ N+ I3 v% _- M- A- m& H
211钩子 6 n5 q. t9 j6 O- e
21.2消息钩子 9 A. F+ c1 E! `. [
21.3SetWindowsHookEx()
5 K( Y5 a* L; n  g* J; z21.4键盘消息钩取练习 1 u/ o! ^; g; Y* A4 `) S6 ?6 s
21.4.1练习示例HookMain.exe
- r( Y6 K1 i8 l$ d* H; s21.4.2分析源代码 ; p) B- Z% J7 c; L$ V9 Z  T, B5 W
21.5调试练习
! a! u0 |; w+ h21.5.1调试HookMain.exe
7 f5 S! b- ^2 t21.5.2调试Notepad.exe进程内的KeyHook.dll
6 J/ a, c' P( F* m3 X$ n21.6小结/ u- F4 t2 n; u) c4 s, B
2 X$ p% k9 P/ ]/ I8 j3 c8 _
第22章 恶意键盘记录器9 z2 ]2 ]9 `5 J- M6 m* V

% f6 }! M4 Y% A( B22.1恶意键盘记录器的目标 , @; {+ N! L# d; ?8 S6 C; M
22.1.1在线游戏 - g3 r3 C7 l4 q# z# V8 Z: [2 l
22.1.2网上银行
+ Q+ n( ?* d$ Y. I4 F( }22.1.3商业机密泄露 * H* A; o; b1 j# w
22.2键盘记录器的种类与发展趋势
/ A  z: X1 j5 p% D22.3防范恶意键盘记录器
; u! `( C  ?* S/ H5 Y- k5 [22.4个人信息
. O# ~% _/ a) H0 y! |/ `! e7 h. N 0 E; X5 J* S& t2 l% z( B+ W
第23章 DLL注入
& U# T8 y5 E; ~4 J+ @8 X" D
* Y" M/ `  {9 ]/ i23.1DLL注入 : c1 c: R( r# s. C. \
23.2DLL注入示例
  H$ I; |% t9 J  N7 ~, G5 s9 s; x23.2.1改善功能与修复Bug
0 i% k) C/ L2 ]: d2 R23.2.2消息钩取 , X7 G, B3 p5 U" z, Q
23.2.3API钩取
2 d& \  I; T& z9 M23.2.4其他应用程序 ' M' w5 ?2 G9 x+ w: T! D6 p7 x
23.2.5恶意代码 - `6 |4 o7 _; l- i% ~. l& H# V* |
23.3DLL注入的实现方法 5 z+ }. d! v) S
23.4CreateRemoteThread() # _# R( h! u% T/ O. |
23.4.1练习示例myhack.dll
! S6 n. r; r* c1 T( I23.4.2分析示例源代码 ) j- s+ P  `8 v4 {) H' a" d
23.4.3调试方法 ; Q# x' S; z% o5 y9 C' q
23.5AppInit_DLLs
" q' M! L2 _% p2 }, ^' a: u23.5.1分析示例源码 ; s3 f+ }- d; K: Y( Y5 B1 y5 S* @
23.5.2练习示例myhack2.dll 4 t. S; ~8 W# y8 Z% S
23.6SetWindowsHookEx()—————
; F% z; G% r9 Q& a23.7小结
$ w. O; z* u" J* F/ |7 q/ w 0 P6 [. B! K; x
第24章 DLL卸载 " T' F& r9 I/ ]  [9 _, p0 Q
9 V8 ~5 X0 Y, @! O' L- B
24.1DLL卸载的工作原理
9 I. g% X& g8 v24.2实现DLL卸载
1 m7 T+ I5 D; L6 y24.2.1获取进程中加载的DLL信息
- s3 D( L- A, p9 p24.2.2获取目标进程的句柄 % N$ i, l  g- C* n6 d
24.2.3获取FreeLibrary()API地址
9 D+ d8 ]/ I5 a: q! Y* W24.2.4在目标进程中运行线程   ?) c4 e2 @! T2 i& G, [5 s8 P6 ]
24.3.DLL卸载练习
" u1 k/ U/ C& F5 U* P6 k7 l24.3.1复制文件及运行notepad.exe
9 D" h6 R# _# T24.3.2注入myhack.dll
" j$ K8 O0 [. U" H. r24.3.3卸载myhack.dll
0 t0 `4 N: E4 _2 g5 g
6 |7 ?* h. y5 a" X6 J% K: @" o) B第25章 通过修改PE加载DLL
  {( B& R; T% O* F, s2 T3 B8 E6 j2 K
25.1练习文件
* V$ J/ w' V, q1 b$ V5 R8 B# ?0 n3 s25.1.1TextView.exe
5 m" Z0 c" \" O4 ]25.1.2TextView_patched.exe
  w+ y6 \' Q# j. C# i8 I" `. T25.2源代码—myhack3.cpp
; J; [# m9 v( C% H* Z$ q; i25.2.1DllMain() 9 O( Q! d0 }, m4 s& ]
25.2.2DownloadURL() / Q8 z9 o/ f* q8 P1 M" M
25.2.3DropFile()
+ @7 v- V7 B) s* _9 P$ m. e5 N6 F25.2.4dummy()
" R+ C% C3 }; m" Y25.3修改TextView.exe文件的准备工作
4 K" D$ r% x) P) S1 V6 Z25.3.1修改思路
+ q! r$ u! |+ }0 \& }7 l25.3.2查看IDT是否有足够空间
; A# ?6 X: P  y( x+ o25.3.3移动IDT ' X% g6 V' V. `( U
25.4修改TextView.exe & [$ p# M. _& g4 X7 R% I; j* @7 q
25.4.1修改导入表的RVA值
* w$ e2 {* g9 o& I+ [6 Q( \7 n2 Y25.4.2删除绑定导入表
; b/ \6 C7 I( R( z( p5 Z* F25.4.3创建新IDT
  P5 l% _" j: f- I25.4.4设置Name.INT.IAT
9 l2 ?2 u* R1 w4 S25.4.5修改IAT节区的属性值
; F, w1 J- T# Y& ~" u. N25.5检测验证   W1 Q0 k1 _1 V' p3 q
25.6小结 5 N' P7 p/ U# m  {4 ], u  G
7 A+ t! y+ m2 ?' M2 E
第26章 PETools% Q  a9 q  w0 _. F! n8 k
! \6 I# W& c) b0 b5 g9 U/ `
26.1PETools . o: a0 @% g& a! J
26.1.1进程内存转储 3 n/ }! v. ?9 c6 G0 o) v, d+ J
26.1.2PE编辑器 ; G: K4 ?) d; r
26.2小结
# Z. l* a! \* I/ @' w# k* e1 G. s" K- _3 G
第27章 代码注入
/ L- `; {  L5 l+ k4 V( e
+ o$ g8 S; U: G4 x% D2 O6 T6 |27.1代码注入 1 ]* A. B& F3 V% U' l! ]
27.2DLL注入与代码注入
2 j5 Z" U- p2 k" c& s/ E27.3练习示例 " _9 z9 S- m$ `; T! X- C3 s/ B1 A
27.3.1运行notepad.exe
$ }7 j5 y( N5 P3 q# y27.3.2运行Codelnjection.exe
$ x; _, v; s+ e3 L  I. @  k5 E27.3.3弹出消息框
" m: q8 x4 i2 V) w3 M27.4Codelnjection.cpp
9 R3 W* O5 p0 {6 e& p$ x27.4.1main()函数
: E) ~% Q& F' E/ t* Q: M27.4.2ThreadProc()函数 * K- I# A/ ^/ E, l
27.4.3InjectCode()函数
/ o; _7 I7 l/ j, z6 O( I27.5代码注入调试练习
- i; a* @5 P4 f; Z+ T" x27.5.1调试notepad.exe 3 W! [+ T3 x1 k5 C1 J6 y
27.5.2设置OllyDbg选项 / [' f. `& c6 Z! R/ m0 t
27.5.3运行Codelnjection.exe
( N* m7 K- w9 y& l% m27.5.4线程开始代码 * Q% ~+ j9 E2 [$ z
27.6小结
, x. y9 b4 r6 }/ F. |( K  V! t% u" \- E$ \: b6 f+ ~0 E, c& C
第28章 使用汇编语言编写注入代码 * P% U9 {: o7 m
8 D6 m, A. k! h! O& u% ]$ G" y! R
28.1目标 0 ?) Q* K. Q1 @2 e6 C3 f: l( P
28.2汇编编程 . f0 M2 C: E; w2 c, j! R
28.3OllyDbg的汇编命令 4 h8 f- P# m% d% W
28.3.1编写ThreadProc()函数
* X# }6 u0 c# Q% \3 h28.3.2保存文件
: X* P1 @0 I9 f8 w; _28.4编写代码注入程序 0 z1 Z4 T" t& j$ m; J# E  K
28.4.1获取ThreadProc()函数的二进制代码 5 P- v8 _# g! @: r
28.4.2Codelnjection2.cpp * Y5 Z( R- F7 ^
28.5调试练习 # T: a) ^1 n, Y1 |/ x/ ]" d
28.5.1调试notepad.exe " g/ @( w% s4 K, p9 v
28.5.2设置OllyDbg选项
) q& p8 d! T6 N8 i& Q28.5.3运行Codelnjection2.exe : s9 m2 K: L  `' o
28.5.4线程起始代码
! c" \; C" P3 ?: s( t* g9 |28.6详细分析
* ]. I1 F; K  U% O28.6.1生成栈帧
% N& H; t; |; k; q* L4 o6 W% P28.6.2THREAD_PARAM结构体指针   v3 j+ {+ [4 j8 L: a( y
28.6.3"User32.dll"字符串 8 m5 e% J% V; p
28.6.4压入"user32.dll"字符串参数 ; ~8 M/ k) Z6 |( K
28.6.5调用LoadLibraryA("user32.dll")
" ?" _, Q. j; [3 e28.6.6"MessageBoxA"字符串
! A) n  G: _/ b* _" h$ x4 e28.6.7调用GetProcAddress(hMod,"MessageBoxA") , J0 e$ t) x9 H$ [/ e
28.6.8压入MessageBoxA()函数的参数1—MB_OK 7 d! q: h5 B% @+ U1 W. I
28.6.9压入MessageBoxA()函数的参数2—"ReverseCore" ) v) W6 ^5 z# i2 P. I5 ^
28.6.10压入MessageBoxA()函数的参数3—"www.reversecore.com"
$ S$ \9 b! j5 k! I3 x: `3 V+ B28.6.11压入MessageBoxA()函数的参数4—NULL
4 j, x0 T# f9 H! p( ~) `0 j28.6.12调用MessageBoxA()
+ s4 T: x" \5 T& R9 @28.6.13设置ThreadProc()函数的返回值
4 a2 ~# X! D6 Z& `! ?; G5 G28.6.14删除栈帧及函数返回 ) s8 O% I* J8 K( `" K8 }
28.7小结 1 I8 \  j+ b) c. j
. ~" ?6 B1 U& r% p( \% ]1 c$ z! y# @
……
8 T# U: |! C; u! O. T8 T. Z" V5 g% t( z* u+ v
第四部分 API钩取 % R( }3 o5 @0 d* b! Z

: I& [4 F+ y5 y( B5 @  [$ i- d第五部分 64位&Windows内核6 ) A* `" J1 W# I) D" [  D% @
/ o4 X  Y$ Z( b8 S& S2 n
第六部分 高级逆向分析技术 # Y' l1 E8 G# x* _: l

+ n4 q4 M2 L% V8 o5 f4 S第七部分 反调试技术 2 V5 t4 ]0 t# J4 [7 Z

1 c7 ~! N7 o7 g" ?第八部分 调试练习 # i* W) A% \# m$ W) s9 `

) T' y* v& y3 j: x! T' X. v结束语
" d1 Y, W# F3 V* C% I" O- @% y% R; ^9 {! w
索引
: ?' u+ L2 ]% Q4 o- ^! a
# O7 l* g7 h9 U- I7 \
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2016-11-21 17:01:30 | 显示全部楼层
学习逆向的一本好书。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-11-21 17:13:16 | 显示全部楼层
武老师的书呀,支持下`
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-19 14:45:35 | 显示全部楼层
果断买了本。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-7-13 07:30:03 | 显示全部楼层
的确是一本好书推荐大家都要看这本书真的是逆向的开山鼻祖了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-7-19 15:48:00 | 显示全部楼层
小甲鱼出的书吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-8-2 10:44:05 | 显示全部楼层
hello world ! 亮了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-10-4 18:27:06 | 显示全部楼层
逆向太难了,绝望
. Q" q  ~; N$ {3 U
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2017-12-16 20:08:07 | 显示全部楼层
好东西
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-1-19 19:05:46 | 显示全部楼层
有电子版的吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-3 13:36

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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