Final SEH示例1_1

;************************************************************************
;*项目名称:Final SEH示例      *
;************************************************************************
;*代码名称:FEH_1_1.asm              *
;*代码功能:采用修改regEip到新的EIP处继续执行                  *
;************************************************************************
;*代码作者:by lujue, 2006-10-30             *
;************************************************************************

;************************************************************************
;汇编模式定义
;************************************************************************
.386
.model flat,stdcall
option casemap:none

;************************************************************************
;头文件定义
;************************************************************************
include  windows.inc
include  kernel32.inc
includelib kernel32.lib
include  user32.inc
includelib user32.lib

;************************************************************************
;数据段定义
;************************************************************************
.data
szCap  db "Final Exception Handler",0
szMsgOK  db "OK,the exceptoin was handled by final handler!",0         
szMsgERR1 db "修复了ECX!",0

;************************************************************************
;代码段
;************************************************************************
;************************************************************************
;程序入口
;************************************************************************
.code
_start:
         ;调用SetUnhandledExceptionFilter来安装Final SEH
  ;原型很简单SetUnhandledExceptionFilter proto pTopLevelExceptionFilter:DWORD
         lea eax,Final_Handler
         invoke SetUnhandledExceptionFilter,eax
 
 ;************************************************************************
 ;除法异常
 ;************************************************************************
         xor ecx,ecx
         mov eax,200
         cdq
         div ecx          
         invoke MessageBox,NULL,addr szMsgERR1,addr szCap,MB_OK + MB_ICONINFORMATION 
 
 Exit:   invoke ExitProcess,NULL

;********************************************************************
; 函数功能:异常处理回调函数:修改 regEcx 使其不为0
;********************************************************************
Final_Handler:          
  push ebp
  mov ebp,esp

  invoke MessageBox,NULL,addr szMsgOK,addr szCap,MB_OK+MB_ICONEXCLAMATION

  mov ebx,[ebp + 8h] ;ebx指向EXCEPTION_POINTERS结构
  mov esi,[ebx] ;esi指向EXCEPTION_RECORD结构
  mov edi,[ebx + 4h] ;edi指向CONTEXT结构 
  assume esi:ptr EXCEPTION_RECORD,edi:ptr CONTEXT

  lea eax,Exit
  mov [edi].regEip,eax
 
  assume esi:nothing,edi:nothing
 
  ;EXCEPTION_EXECUTE_HANDLER equ 1 这时不出现非法操作的讨厌对话框,程序被终止。
         ;mov eax,EXCEPTION_EXECUTE_HANDLER 

  ;EXCEPTION_CONTINUE_SEARCH equ 0 出现非法操作的讨厌对话框,这时是调用系统默认的异常处理过程,程序被终结了
         ;mov eax,EXCEPTION_CONTINUE_SEARCH 

         ;EXCEPTION_CONTINUE_EXECUTION equ -1 不断出现对话框,你将陷入死循环,如果没有修复ecx,就会不断产生异常,然后不断调用这个例程而死循环,
  ;除非更改流向,或修复,或用EixtProcess退出进程,这里我们作了修复,程序正常终止。                 
         mov eax,EXCEPTION_CONTINUE_EXECUTION 
 
  mov esp,ebp
  pop ebp
Err_Exit:   
  ret
 
end _start
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值