覆盖关键变量劫持控制流

程序中的关键变量:

    栈中的关键变量: ebp,   ret_addr

    虚函数指针:子类对父类的继承 能够对函数进行重写 由虚函数表来进行操作

原理 :

虚函数是一种C++中的函数,使用virtual进行定义,用于 实现C++的多态性,即将接口和实现区分开来,对于不同 的类采用不同的方式实现同一个方法。

如果一个父类A中声明了一个方法,效果是输出字符A, 其继承类B中对该方法进行了重写,效果是输出字符B。

这个方法不声明为虚函数的话,对B中函数的调用仍会调 用A中的函数,即输出A。

虚函数能够进行重写 :

 在C++语言中,会为虚函数建立一个虚函数表,其位置就 存储在新申请的类的内存空间的首部。

 虚函数表中依次存放着该类中的所有的虚函数的地址。当 类被继承的时候,子类也会从父类那里继承这个虚函数表

  如果子类中对某一虚函数进行了重写,那么虚函数表中就 会将该虚函数的地址改为子类重写的函数的地址。

  这样在访问的时候就会直接调用了重写的函数而不是原父 类中的函数。

利用方法介绍:

修改虚函数表指针  修改其中函数指针 影响函数调用

SEH链结构中的关键变量:

SEH介绍

程序异常处理结构  不同回调函数处理不同的异常  每个节点尝试调用一个 回调函数

利用方法介绍

修改异常处理结构中异常处理函数指针  修改指向下一结构的指针 影响异常处理

 

 

 

你可能感兴趣的:(覆盖关键变量劫持控制流)