本系列主要为二进制安全打基础,适合一些小白食用
IDE(集成开发环境)
如今的开发工作基本都在IDE中完成,而IDE包含编辑器+调试器+编译器(解释器);编辑器用来进行文件编辑,调试器进行代码调试,编译器进行代码编译(针对编译语言)、解释器用于运行代码(针对解释型语言)
C语言属于编译型语言
常见编译器
编译器:GCC、MSVC、G++
生成可执行文件的步骤:
1.编写代码
#include <stdio.h> #define MAX_NUMBER 12 int main() { printf("Hello World!!%d/r/n",MAX_NUMBER); return 0; }
2.编译 :包含三个步骤->预处理、编译、汇编
<1>预处理 : 替换头文件文件、处理预编译数据(所有的宏都会被替换成值)、注释行头有#的内容就会在预处理阶段的时候进行处理 gcc -E hello.c -o hello.i <2>编译:将C代码编译为汇编代码 gcc -S hello.i -o hello.s cat hello.s --->汇编代码 Windows =>PE Linux => ELF(Linux的file命令:可以用来查看文件的类型;如:file hello) 如果是在Windows平台中生成的程序则会有PE文件标识,如果在Linux平台中生成则会有ELF标识 <3>汇编:将汇编代码汇编成二进制代码(不能直接运行,因为没有将库链接进来) gcc -C hello.s -o hello.o
3.链接
gcc hello.o -o hello 最终链接成可执行文件 需要将调用的库连接进二进制代码中才能形成最后的可执行文件
4.运行
#前面这些步骤主要目的是为了理解从C代码到可执行程序的全过程,在实际编译的时候可以直接一步到位
gcc hello.c -o hello 直接一步到位(生成可执行程序)
gcc分别生成32/64位程序
gcc hello.c -o hello -m32 #生成32位的可执行程序 gcc hello.c -o hello -m64 #生成64位的可执行程序
补充:若无法确定对方主机的架构,可统一生成32为木马程序,因为64位系统可以运行32位程序,但是32位系统无法执行64位程序。