MuddyWaterPsDecode.py

#APT #MuddyWater

alpha1 = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'
alpha2 = 'NOPQRSTUVWXYZABCDEFGHIJKLMnopqrstuvwxyzabcdefghijklm'
fileName = 'C:\\Users\\xxx\\Desktop\\malware\\MuddyWater.txt'
outfileName = 'C:\\Users\\xxx\\Desktop\\malware\\MuddyWater_decode.txt'

def decode(strEnc):
    return strEnc.translate(str.maketrans(alpha2, alpha1))#rot13


if __name__ == '__main__':
    with open(outfileName, "w+", encoding='utf-8') as file:
        with open(fileName) as f:
            content = f.readlines()
            for line in content:
                pattern1 = re.compile('function \w+')
                result1 = pattern1.findall(line)
                if result1 != []:
                    result = result1[0].split('function ')[1]
                    rot13 = decode(result)
                    line = line.replace(result,rot13)
                    #line = re.sub( result, rot13, line, count=0, flags=0)#替换
                    #print(line)

                pattern2 = re.compile('\$\w+')
                result2 = pattern2.findall(line)
                if result2 != []:
                    for value in result2:
                        rot13_1 = decode(value)
                        line = line.replace(value,rot13_1)
                        #line = re.sub(value, rot13_1, line, count=0, flags=0)#替换
                #print(line)
                file.write(line)
                file.flush()
        f.close()
        file.close()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值