本文目錄一覽:
Python 加密程序
#coding=utf-8
””’
Description: 可逆的加密與解密
Environment: python2.5.x
Author:idehong@gmail.com
”’
import os
import sys
class Code(object):
””’可逆的加密與解密”’
def __init__(self, key = “idehong@gmail.com”):
self.__src_key = key
self.__key = self.__get_strascii(self.__src_key, True)
def encode(self, value):
””’加密函數, 加密後為一串數字”’
return “%d” % (self.__get_strascii(value, True) ^ self.__key)
def decode(self, pwd):
””’解密函數”’
if self.is_number(pwd):
return self.__get_strascii( (int(pwd)) ^ self.__key, False )
else:
print ‘require number.’
def reset_key(self, key):
””’重新設置key”’
self.__src_key = key
self.__key = self.__get_strascii(self.__src_key, True)
#===============================================================================
# 內部調用接口
#===============================================================================
def __get_strascii(self, value, bFlag):
if bFlag:
return self.__get_str2ascii(value)
else:
return self.__get_ascii2str(value)
def __get_str2ascii(self, value):
ls = []
for i in value:
ls.append( self.__get_char2ascii( i ) )
return long(“”.join(ls))
def __get_char2ascii(self, char):
””’獲取單個字符的acsii碼值”’
try:
return “%03.d” % ord(char)
except (TypeError, ValueError):
print “key error.”
exit(1)
def __get_ascii2char(self, ascii):
if self.is_ascii_range(ascii):
return chr(ascii)
else:
print “ascii error(%d)” % ascii
exit(1)
def __get_ascii2str(self, n_chars):
ls = []
s = “%s” % n_chars
n, p = divmod(len(s), 3)
if p 0:
nRet = int(s[0 : p])
ls.append( self.__get_ascii2char(nRet))
pTmp = p
while pTmp len(s):
ls.append( self.__get_ascii2char( int(s[pTmp: pTmp + 3])) )
pTmp += 3
return “”.join(ls)
#================================================================================
# 工具接口
#================================================================================
def is_number(self, value):
try:
int(value)
return True
except (TypeError, ValueError):
pass
return False
def is_ascii_range(self, n):
return 0 = n 256
def is_custom_ascii_range(self, n):
return 33 = n 48 or 58 = n 126
class Usage(object):
””’
命令行參數讀取與解析
”’
def __init__(self):
self._clsWork = Code()
self._args_dic = {‘arg_help’ : [‘-?’, ‘-help’],
‘arg_p’ : [‘-p’, ‘-pwd’],
‘arg_t’ : [‘-t’, ‘-text’],
‘arg_k’ : [‘-k’, ‘-key’],
}
def help(self, *k):
strHelp = “Usage: pwd [-options] [args…] where option include:”
strHelp += “””
-? -help print this help message
-k key_str -p pwd_str
-k key_str -t text_str”””
print strHelp
def args(self, argv_ls):
””’dispatch command”’
# print argv_ls
if len(argv_ls) = 1 or len(argv_ls) 5:
print ‘Unrecognized option’
return
cmd_dic = {}
curr_cmd = ”
# control command
for i, v in enumerate(argv_ls[1:]):
for j in self._args_dic.items():
# add command
if v in j[1] and j[0] not in cmd_dic:
curr_cmd = j[0]
cmd_dic[curr_cmd] = []
break
else:
# add argv
if cmd_dic:
cmd_dic[curr_cmd].append(v)
# exec command
if cmd_dic:
self.exec_cmd(cmd_dic)
else:
print ‘Unrecognized option’
def exec_cmd(self, cmd_dic):
””’exec cmd”’
if len(cmd_dic) == 2:
if ‘arg_p’ in cmd_dic and ‘arg_k’ in cmd_dic\
and len(cmd_dic[‘arg_p’]) == 1 and len(cmd_dic[‘arg_k’]) == 1:
self._clsWork.reset_key(cmd_dic[‘arg_k’][0])
print self._clsWork.encode(cmd_dic[‘arg_p’][0])
return
elif ‘arg_t’ in cmd_dic and ‘arg_k’ in cmd_dic\
and len(cmd_dic[‘arg_t’]) == 1 and len(cmd_dic[‘arg_k’]) == 1:
self._clsWork.reset_key(cmd_dic[‘arg_k’][0])
print self._clsWork.decode(cmd_dic[‘arg_t’][0])
return
self.help()
if __name__ == ‘__main__’:
usage = Usage()
usage.args(sys.argv)
像這樣的python程序如何解密?
這樣的不叫加密,無所謂解密不解密的,這樣的就是Obfuscation,該怎麼看就怎麼看,只不過變量名字難認而已。你隨便找個文本編輯器用FindReplace改個容易認的名字就應該能看懂了。
python封裝成exe如何加密
可以直接用加密軟件加密。據了解加密軟件可以加密所有類型文件的,可以對文件進行透明加密,在內部環境文件是可以正常打開的,脫離這個環境則打不開或亂碼,可以禁止截屏、拷貝、複製、打印、修改等。文件外發需授權解密,未授權解密無論以任何形式發出都是無法正常打開的,還可設置文件外發的瀏覽次數和打開時間。在不影響日常使用的情況下保障文件安全。
python 編程 有了加密程序,怎麼寫解密程序
對 Python 加密時可能會有兩種形式,一種是對Python轉成的exe進行保護,另一種是直接對.py或者.pyc文件進行保護,下面將列舉兩種形式的保護流程。
1、 對 python轉exe加殼
下載最新版Virbox Protector加殼工具,使用加殼工具直接對demo.exe進行加殼操作
2、對.py/.pyc加密
第一步,使用加殼工具對 python 安裝目錄下的 python.exe 進行加殼,將 python.exe 拖入到加殼工具 VirboxProtector 中,配置後直接點擊加殼。
第二步,對.py/.pyc 進行加密,使用 DSProtector 對.py/.pyc 進行保護。
python exe如何防止反編譯
Python 編譯生成 pyc 僅僅為了提升加載速度,並不是為了防止破解,反編譯後和原來一模一樣。pyinstaller,py2exe,只是把 pyc 打個包,同樣很弱。代碼混淆也只能增加看懂代碼的難度,但並不能防止破解。所以最為穩妥的辦法只有修改Python解釋器,對源代碼進行加密,解釋器加載源代碼時再解密,這種方法雖然可以防止破解,但給自己帶來麻煩不說,發布程序是需要打包自己修改後的解釋器,相當麻煩。
原創文章,作者:HUCG,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/131513.html