SEH溢出

_try
{
    strcpy(buf,input);

    zero=4/zero;
}
_except(MyExceptionhandler){}

SEH结构存放在系统栈中,当线程初始化时,会自动向栈中安装一个SEH,作为线程默认的异常处理。如果程序代码使用了tryexcept,或者assert宏等异常处理机制,编译器将最终通过当前函数栈帧中安装一个seh来实现异常处理,栈中一般有多个seh,多个seh通过链表指针在栈内由栈顶向下传成链表,最顶端的seh通过teb的0自己偏移处的指针标识,当异常发生操作系统会中断程序,并先从teb的0自己读取距离栈顶最近的seh使用异常处理函数句柄所指向的代码来处理异常,当离出事最近的异常处理函数运行失败时,将顺着seh链依次尝试其他,如果程序安装所有异常处理都不能处理,采用默认异常处理函数,通常弹错误对话框,然后其强制关闭程序。

所以可以栈溢出那样覆盖返回地址的形式去覆盖seh处理函数的地址。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值