python實(shí)現(xiàn)的微盾解密算法
作者: 鄭曉 分類: Python 發(fā)布于: 2013-12-05 17:50 瀏覽:5,903 評論(2)
python實(shí)現(xiàn)的微盾解密算法
又是段簡單的python練手代碼,這兩天看了一套php源碼中有不少php文件被用微盾加密過,網(wǎng)上也有不少的php版微盾解密算法,看了下算法,都是一些比較簡單的方法去實(shí)現(xiàn)的,正好自己這兩天也在學(xué)習(xí)python,就拿來練練手,用python實(shí)現(xiàn)了出來。
基本算法寫了出來做成批量解密也就so easy了,tkinter也學(xué)了一些,有時間的話就再給它改成圖形界面的。
import os #文件操作
import re #正則
import base64 #base64解碼
jiamifilename = 'jiemi.php' #待解密文件
lines = []
#打開文件,將數(shù)據(jù)放入列表
with open(jiamifilename,'r') as fp:
for line in fp:
lines.append(line)
fp.close()
#第一次base64解碼
p = re.compile("O0O0000O0\('.*'\)")
y = p.findall(lines[1])
content = ''
if y:
content=y[0].replace("O0O0000O0('","")
content=content.replace("')","")
content=str(base64.b64decode(content))
#準(zhǔn)備從第一次base64解碼后的內(nèi)容中查找密鑰
decode_key=""
p = re.compile("\),'.*',")
k = p.findall(content)
if k:
decode_key = k[0].replace("),'", "")
decode_key = decode_key.replace("',","")
#查找要截取字符串長度
str_length=""
p = re.compile(",\d*\),")
k = p.findall(content)
if k:
str_length = k[0].replace("),","")
str_length = str_length.replace(",","")
#截取文件加密后的密文
Secret = lines[2][int(str_length):]
#準(zhǔn)備還原密文
li = list('ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/')
li_len = len(li)
xx = ''
for x in Secret:
i = decode_key.index(x)
if i>=li_len:
xx += x
continue
xx += li[i]
#整理還原后的數(shù)據(jù),準(zhǔn)備輸出到文件。
strs = base64.b64decode(xx.encode())
with open('decode.php', 'w') as f:
f.write('')
f.close()
print('文件解密成功!')
input()
什么是PS:這兩天發(fā)現(xiàn)鄭曉個人博客的關(guān)鍵詞:“個人博客”排名又上來了,爭取下看能不能再回到首頁。。。
本文采用知識共享署名-非商業(yè)性使用 3.0 中國大陸許可協(xié)議進(jìn)行許可,轉(zhuǎn)載時請注明出處及相應(yīng)鏈接。
本文永久鏈接: http://m.yjfs.org.cn/micro-shield-decryption-algorithm-implemented-python.html
世界在變、互聯(lián)網(wǎng)在變、網(wǎng)絡(luò)營銷在變,SEO同樣在變,所以我們SEOer的觀點(diǎn)更需要變了,在不變就out了?。?!
本文由說說seo論壇編輯,轉(zhuǎn)載請備注原文地址: