设为首页  
联系我们  
加入收藏  
网页制作 冲浪宝典 图形图像 操作系统 软件教学 编程开发 认证考试 安全技术 站长专区 文学驿站 娱乐天地 游戏天地 办公软件
文章搜索
您的位置: 首页 >> 文章首页 >> 安全技术 >> 病毒漏洞 >> CIH 病毒原理的应用
精品推荐
病毒漏洞点击TOP10
·动网论坛上传文件漏洞
·常用几种软件密码破解的方法
·尘缘雅境图文系统存在严重漏洞
·Raw Socket(原始套接字)实现Sniffer(嗅探)
·远程线程注入版获取SYSTEM权限
·“艾妮”(ANI)病毒解决方案
·如何成为一名黑客(附FAQ)
·能开启摄像头偷窥隐私的病毒
·解决DF冰点不修改NTLDR,最后一次正确配置的问题
·CGI漏洞
安全技术点击TOP10
·主板芯片级维修技术资料
·Symantec AntiVirus防病毒服务器安装配置使用指南
·教你如何手动查杀“幽灵(I-Worm.Ghost)”病毒
·贴片元件标记对应型号资料
·主板芯片组详解
·在WindowsXP/2003下查看端口对应的进程
·主板点不亮(不显示)的BIOS修复两法
·计算机启动过程详解
·网吧如何禁止使用PP点点通
·主板开机原理
精选专题

CIH 病毒原理的应用

作者: 来源:网络文章 时间:2005-12-17 23:58:07

CIH 病毒原理的应用(1)

Windows 95/98应用程序无法直接读写物理内存,如果使用VxD编程,可以调用VMM功能_MapPhysToLinear 将物理地址 

   映射到线性地址再进行修改,但是这样就必须单独写一个VxD,比较麻烦,那么能不能在应用程序中直接调用VMM功能呢? 

   一般不能,因为VMM功能要在Ring 0上调用,而一般的应用程序工作在Ring 3上,那么为什么CIH 病毒能够调用VMM功能呢, 

   CIH病毒使用了一种技术,采用Intel处理器的中断从Ring 3转到Ring 0,我们完全可以借鉴这种技术来调用VMM功能, 下 

   面的程序演示了如何修改物理内存——以在Windows 95加密程序中修改加密扇区大小(物理地址0000:0525H)为例: 

   ;**************************************************************************** 

   ;* Windows 95加密软件核心模块之一--磁盘扇区大小修改程序 * 

   ;* * 

   ;* 本程序在Windows 95下修改内存物理地址0000:0525 处的磁盘扇区大小字节, * 

   ;* 为了能够修改物理地址,本程序使用了VMM 功能_MapPhysToLinear将物理地址映射 * 

   ;* 到线性地址进行修改。为了在应用程序中调用VMM 功能,本程序使用了CIH 病毒的 * 

   ;* 原理,使用中断将系统由Ring 3转到Ring 0,然后调用VMM 功能。 * 

   ;* 本程序中的过程ChangeSectorSize在VC中的原型可以写成: * 

   ;* * 

   ;* void _stdcall ChangeSectorSize(BYTE SectorSize); * 

   ;**************************************************************************** 

   .386p 

   .model flat,stdcall 

   ;修改的中断号,如果本中断号改成3则可以防止Soft-ICE跟踪! 

   HookExceptionNo EQU 05h 

   .data 

   IDTR_1 db 6 dup(0) ;保存中断描述符表寄存器 

   OldExceptionHook dd 0 ;保存原先的中断入口地址 

   .code 

   ;修改扇区大小过程 

   ChangeSectorSize PROC SectorSize:BYTE 

   push eax 

   ;获取修改的中断的中断描述符(中断门)地址 

   sidt IDTR_1 

   mov eax,dWord ptr IDTR_1+02h 

共3页 9 7 [1] [2] [38 :>

CIH 病毒原理的应用 相关文章:
CIH 病毒原理的应用 相关软件:
特别声明:本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
转载请注明来源:http://www.xgdown.com