1.复制自身程序到windows目录和系统目录下:

 #include <windows.h>
#include <stdio.h>
#include <string.h> void CopySelf(); int main(){
CopySelf();
return ;
}
void CopySelf(){
char szSelfName[MAX_PATH]={};
char szWindowsPath[MAX_PATH]={};
char szSystemPath[MAX_PATH]={}; GetModuleFileName(NULL,szSelfName,MAX_PATH);
GetWindowsDirectory(szWindowsPath,MAX_PATH);
GetSystemDirectory(szSystemPath,MAX_PATH); strcat(szWindowsPath,"\\backdoor.exe");
strcat(szSystemPath,"\\backdoor.exe"); CopyFile(szSelfName,szWindowsPath,FALSE);
CopyFile(szSelfName,szSystemPath,FALSE);
}

相关API介绍:

1>获得自身程序所在路径的API定义:

DWORD GetModuleFileName{
HMODULE hModule, //handle to module
LPTSTR lpFilename, //file name of module
DWORD nSize //size of buffer
};

三个参数,分别如下:

hModule:该参数在获得自身程序时使用为NULL。

lpFilename:该参数指定一个字符型的缓冲区,用于保存程序自身所在的路径。

nSize:该参数指定缓冲区的大小。

2>获得Windows目录的API的定义:

UINT GetWindowsDirectory{
LPTSTR lpBuffer, //buffer for Windows directory
UINT uSize //size of directory buffer
};

两个参数,分别如下:

lpBuffer:指定一个字符型的缓冲区,用于保存Windows目录的路径。

uSize:指定缓冲区的大小。

3>获得系统目录的API函数的定义:

UINT GetSystemDirectory{
LPTSTR lpBuffer, //buffer for system directory
UINT uSize //size of directory buffer
};

两个参数,分别如下:

lpBuffer:指定一个字符型的缓冲区,用于保存系统目录的路径。

uSize:指定缓冲区的大小。

4>拷贝文件的API函数的定义:

BOOL CopyFile{
LPCTSTR lpExistingFileName, //name of an existing file
LPCTSTR lpNewFileName, //name of new file
BOOL bFailIfExists //operation if file exists
};

三个参数,分别如下:

lpExistingFileName:指向一个已存在文件的路径,即原文件路径。

lpNewFileName:指向一个新的文件的位置,即欲拷贝到的文件的目的路径。

bFailIfExists:一个布尔型参数,如果参数为TRUE,若目的文件已存在则返回,复制失败;如果参数为FALSE,,若目的文件已存在则强行覆盖原有的文件。

2.获得系统的相关信息:

 #include <windows.h>
#include <stdio.h> void GetSysInfo(); int main(){
GetSysInfo();
return ;
}
void GetSysInfo(){
char szComputerName[MAXBYTE]={};
char szUserName[MAXBYTE]={};
unsigned long nSize=MAXBYTE;
OSVERSIONINFO OsVer; OsVer.dwOSVersionInfoSize=sizeof(OSVERSIONINFO);
GetVersionEx(&OsVer); if(OsVer.dwPlatformId==VER_PLATFORM_WIN32_NT){
if(OsVer.dwMajorVersion==&&OsVer.dwMinorVersion==)
printf("Windows XP %s \r\n",OsVer.szCSDVersion);
else if(OsVer.dwMajorVersion==&&OsVer.dwMinorVersion==)
printf("Windows 2K \r\n");
}else{
printf("Other System \r\n");
} GetComputerName(szComputerName,&nSize);
printf("Computer Name is %s \r\n",szComputerName); nSize=MAXBYTE;
GetUserName(szUserName,&nSize);
printf("User Name is %s \r\n",szUserName);
}

相关API介绍如下:

1>获取操作系统版本:

BOOL GetVersionEx{
LPOSVERSIONINFO lpVersionInfo //version information
};

一个参数,如下:

lpVersionInfo:指向一个OSVERSIONINFO结构的指针。

typedef struct _OSVERSIONINFO{
DWORD dwOSVersionInfoSize; //结构体大小
DWORD dwMajorVersion; //主版本号
DWORD dwMinorVersion; //次版本号
DWORD dwBuildNumber;
DWORD dwPlatformId; //平台ID
TCHAR szCSDVersion[]; //补丁包
}OSVERSIONINFO;

dwPlatformId的取值有3个,而现在主要使用一个,即VER_PLATFORM_WIN32_NT。

2>获取计算机名称:

BOOL GetComputerName{
LPTSTR lpBuffer, //computer name
LPDWORD lpnSize //size of name buffer
};

两个参数,分别如下:

lpBuffer:保存计算机名称缓冲区。

lpnSize:保存缓冲区的长度,该参数是一个输入/输出参数。

3>获取当前用户名称:

BOOL GetUserName{
LPTSTR lpBuffer, //name buffer
LPDWORD nSize //size of name buffer
};

两个参数,分别如下:

lpBuffer:保存当前用户名称的缓冲区。

nSize:保存缓冲区的长度,该参数是一个输入/输出参数。

简单API练手:(1)复制自身程序到windows目录和系统目录下;(2)获得系统的相关信息。的更多相关文章

  1. 复制自身程序到windows目录和system32目录下

    功能:复制自身到windows目录和system32目录下. 参考代码: #include <stdio.h> #include <windows.h> void CopySe ...

  2. Xamarin入门,开发一个简单的练手APP

    之前周末用Xamarin练手做了个简单APP,没有啥逻辑基本就是个界面架子,MVVM的简单使用,还有Binding,Command的简单使用,还有一个稍微复杂点两个界面交互处理(子页面新增后关闭,父页 ...

  3. Socket程序从windows移植到linux下需要注意的

    )头文件 windows下winsock.h或winsock2.h linux下netinet/in.h(大部分都在这儿),unistd.h(close函数在这儿),sys/socket.h(在in. ...

  4. jquery数据验证插件(自制,简单,练手)

    一:最近项目中js数据验证比较多,为了统一风格,移植复用,于是顺手封装了Jquery的插件. (function($) { var defaults = { bugColor: '#FFCCCC', ...

  5. Cocos2d-Lua (练手) 微信打飞机

    学习下lua,目前入门级,使用版本为 v3.3 Final For Win,空闲时间不足,只能断断续续写点东西.   一.子弹效果          子弹只做了一种,扇形发射,可以增加扇形大小,子弹的 ...

  6. 第一个手写Win32窗口程序

    第一个手写Win32窗口程序 一 Windows编程基础 1 Win32应用程序的基本类型 1.1 控制台程序 不需要完善的Windows窗口,可以使用DOS窗口 的方式显示. 1.2 Win32窗口 ...

  7. WEB服务器4--IIS中网站、Web应用程序和虚拟目录

    网站.Web应用程序和虚拟目录 在IIS中可以创建网站.Web 应用程序和虚拟目录,以便与计算机网络上的用户共享信息. “网站”.“Web 应用程序”和“虚拟目录”这三个概念的关系如图 8‑1所示. ...

  8. 【开源】前端练手笔记,Chrome扩展应用程序(html+CSS+JS) (1)

    项目名称:github-notification 项目地址:https://github.com/WQTeam/github-notification 说明:本人打算抽时间学习前端(html + cs ...

  9. 微信小程序初体验,入门练手项目--通讯录,后台是阿里云服务器(一)

    内容: 一.前言 二.相关概念 三.开始工作 四.启动项目起来 五.项目结构 六.设计理念 七.路由 八.部署线上后端服务 同步交流学习社区: https://www.mwcxs.top/page/4 ...

随机推荐

  1. SqlServer缓存依赖 示例

    ------------------------------------------------------------c#代码----------------------using System; ...

  2. ubuntu16切换hosts软件安装

    之前用ubuntu切换hosts以为没有软件可用,直接用cp来替换hosts文件,今天网上搜了一下发现一个软件和window上用的切hosts功能一样,而且可以支持linux,mac,windows. ...

  3. Java中替换字符串中特殊字符+ 20150921

    需求:今天需要将字符串中的" +"转换程"%2B",但是"+"是正则表达式中的特殊字符,使用需要反斜杠转义,具体示范: String a=& ...

  4. 控制led灯并显示自己的数值

    前提是有led.jar包封装好了东西 1.并设置好led灯的模式并打开串口. 2.在布局中创建一个EditText ,Button.并利用-.getText.toString().trim(); 来获 ...

  5. JAVA四则运算算法

    一.程序要求 解析一般数学算式,实现简单的带括号的加减乘除运算. 二.基本思路 前面两篇介绍了直接解析字符串和用数组容器辅助解析的两种方式,这次再介绍最常用的解析算法——解析后缀表达式(逆波兰表达式) ...

  6. 在IIS服务上发布网站

    一.打开控制面板中的“管理工具” 二.打开IIS管理器 三.右键网站,选择“新建网站”

  7. DFS&&BFS

    DFS DFS搜索是按照深度的方向搜索,它类似于树的先根遍历,是树的先根遍历的推广. 1.从图的某个顶点v0出发,首先访问v0, 2.找出刚访问过的顶点的第一个未被访问过的邻接点,然后访问该结点,以该 ...

  8. Linux下用文件IO的方式操作GPIO(/sys/class/gpio)(转)

    通过sysfs方式控制GPIO,先访问/sys/class/gpio目录,向export文件写入GPIO编号,使得该GPIO的操作接口从内核空间暴露到用户空间,GPIO的操作接口包括direction ...

  9. MAC OX 配置 Tomcat 说明

    1: 首先在官网下载 Tomcat(我选择的是最新的9.0) , http://tomcat.apache.org/ 2:下载完成之后将压缩包解压在/Library/下 可使用快捷键 control+ ...

  10. Sql Server中的事务隔离级别

    数据库中的事物有ACID(原子性,一致性,隔离性,持久性)四个特性.其中隔离性是用来处理并发执行的事务之间的数据访问控制.SqlServer中提供了几种不同级别的隔离类型. 概念 Read UnCom ...