了解PoC、Exp、Payload 与 Shellcode的概念与区别

在这篇文章中将解释渗透中关于PoC、Exp、Payload 与 Shellcode的区别

基本概念

PoC,全称 "Proof of Concept",中文"概念验证",常指一段漏洞证明的代码。

Exp,全称 "Exploit",中文"利用",指利用系统漏洞进行攻击的动作。

Payload,中文 "有效载荷",指成功 exploit 之后,真正在目标系统执行的代码或指令。

Shellcode,简单翻译 "shell 代码",是 Payload 的一种,由于其建立正向/反向 shell 而得名。

注意

PoC 是用来证明漏洞存在的,Exp 是用来利用漏洞的,两者通常不是一类,或者说,PoC 通常是无害的,Exp 通常是有害的,有了 PoC,才有 Exp。

Payload 有很多种,它可以是 Shellcode,也可以直接是一段系统命令。同一个 Payload 可以用于多个漏洞,但每个漏洞都有其自己的 Exp,也就是说不存在通用的 Exp。

Shellcode 也有很多种,包括正向的,反向的,甚至 meterpreter。

Shellcode 与 Shellshcok 不是一个,Shellshock 特指 14 年发现的 Shellshock 漏洞。

总结

想象自己是一个特工,你的目标是监控一个重要的人,有一天你怀疑目标家里的窗子可能没有关,于是你上前推了推,结果推开了,这是一个 PoC,于是你回去了,开始准备第二天的渗透计划,第二天你通过同样的漏洞渗透进了它家,仔细查看了所有的重要文件,离开时还安装了一个隐蔽的'qie听器',这一天你所做的就是一个 Exp,你在他家所做的就是不同的 Payload,就把'qie听器'当作 Shellcode 吧!

posted @ 2022-11-25 10:51  周知行  阅读(649)  评论(0编辑  收藏  举报