python加密cython_python通过cython加密代码

#coding=utf-8

import getopt

import os, sys

import zipfile

from Crypto.Cipherimport AES

import random, struct

#加密python3的代码

def transfer3(dir_pref):

os.system('cython -2 %s.py;'

'gcc -c -fPIC -I/usr/include/python3.5/ %s.c -o %s.o'

% (dir_pref, dir_pref, dir_pref))

os.system('gcc -shared %s.o -o %s.so' % (dir_pref, dir_pref))

if clear:

os.system('rm -f %s.c %s.o %s.py' % (dir_pref, dir_pref, dir_pref))

else:

os.system('rm -f %s.c %s.o' % (dir_pref, dir_pref))

#加密python2的代码

def transfer2(dir_pref):

os.system('cython -2 %s.py;'

'gcc -c -fPIC -I/usr/include/python2.7/ %s.c -o %s.o'

% (dir_pref, dir_pref, dir_pref))

os.system('gcc -shared %s.o -o %s.so' % (dir_pref, dir_pref))

if clear:

os.system('rm -f %s.c %s.o %s.py' % (dir_pref, dir_pref, dir_pref))

else:

os.system('rm -f %s.c %s.o' % (dir_pref, dir_pref))

#加密AI模型

def encrypt_file(in_filename, out_filename=None, chunksize=64*1024):

"""

使用AES(CBC模式)加密文件给定的密钥。

:param key: 加密密钥-必须是16、24或32字节长。长按键更安全。

:param in_filename: 输入的文件的名称

:param out_filename: 如果为None,将使用“.enc”。

:param chunksize: 设置函数用于读取和加密文件。大块一些文件和机器的大小可能更快。块大小必须可被16整除。

:return: None

"""

if not out_filename:

out_filename= in_filename+ '.enc'

salt= ''# 盐值

key= "{: <32}".format(salt).encode("utf-8")

#iv = ''.join(chr(random.randint(0, 0xFF)) for i in range(16))

#encryptor = AES.new(key, AES.MODE_CBC, iv)

iv= b'0000000000000000'

encryptor= AES.new(key, AES.MODE_CBC, iv)

filesize= os.path.getsize(in_filename)

withopen(in_filename,'rb') as infile:

withopen(out_filename,'wb') as outfile:

outfile.write(struct.pack('

outfile.write(iv)

while True:

chunk= infile.read(chunksize)

if len(chunk)== 0:

break

elif len(chunk)% 16 != 0:

chunk+= (' ' * (16 - len(chunk)% 16)).encode("utf-8")

outfile.write(encryptor.encrypt(chunk))

def zip_dir(dir_path,out_path):

"""

压缩指定文件夹

:param dir_path: 目标文件夹路径

:param out_path: 压缩文件保存路径+xxxx.zip

:return: 无

"""

zip = zipfile.ZipFile(out_path,"w", zipfile.ZIP_DEFLATED)

for path, dirnames, filenamesin os.walk(dir_path):

# 去掉目标跟路径,只对目标文件夹下边的文件及文件夹进行压缩

fpath= path.replace(dir_path, '')

for filenamein filenames:

zip.write(os.path.join(path, filename), os.path.join(fpath, filename))

zip.close()

if __name__== '__main__':

help_show= '''

python version:

python3        该代码用于加密python3编写的代码,将.py文件转换成.so文件,达到加密的效果

python2        该代码用于加密python2编写的代码,将.py文件转换成.so文件,达到加密的效果

Options:

-h,  --help       显示帮助

-d,  --directory  你需要加密的文件夹

-o,  --operation  你所需要执行的操作,python3 or python2 or model

-f,  --file       加密单个py文件

-c,  --clear      删除原始的py文件

-m,  --maintain   列出你不需要加密的文件和文件夹,如果是文件夹的话需要加[]

例子: -m __init__.py,setup.py,[poc,resource,venv,interface]

-z,  --zip        加密之后压缩文件

Example:

python setup.py -f test_file.py -o python2     加密单个文件

python setup.py -d test_dir -o python2 -m __init__.py,setup.py,[poc/,resource/,venv/,interface/] -c      加密文件夹

python3 setup.py -f test_file.py  -o python3    加密单个文件

python3 setup.py -d test_dir -o python3 -m __init__.py,setup.py,[poc/,resource/,venv/,interface/] -c      加密文件夹

'''

clear= 0

is_zip= False

root_name= ''

operation= ''

file_name= ''

m_list= ''

try:

options,args= getopt.getopt(sys.argv[1:],"vh:d:f:cm:o:z:",["version","help","directory=","file=","operation=","zip","clear","maintain="])

except getopt.GetoptError:

print(help_show)

sys.exit(1)

for key, valuein options:

if keyin ['-h','--help']:

print(help_show)

elif keyin ['-c','--clear']:

clear= 1

elif keyin ['-d','--directory']:

root_name= value

elif keyin ['-f','--file']:

file_name= value

elif keyin ['-o','--operation']:

operation= value

elif keyin ['-z','--zip']:

is_zip= True

elif keyin ['-m','--maintain']:

m_list= value

file_flag= 0

dir_flag= 0

if m_list.find(',[') != -1:

tmp= m_list.split(',[')

file_list= tmp[0]

dir_list= tmp[1:-1]

file_flag= 1

dir_flag= 1

elif m_list.find('[') != -1:

dir_list= m_list[1:-1]

dir_flag= 1

else:

file_list= m_list.split(',')

file_flag= 1

if dir_flag== 1:

dir_tmp= dir_list.split(',')

dir_list=[]

for din dir_tmp:

if d.startswith('./'):

dir_list.append(d[2:])

else:

dir_list.append(d)

if root_name != '':

if not os.path.exists(root_name):

print('No such Directory, please check or use the Absolute Path')

sys.exit(1)

if os.path.exists('%s_old' % root_name):

os.system('rm -rf %s_old' % root_name)

#os.system('cp -r %s %s_old' % (root_name, root_name))   #备份源文件

try:

for root, dirs, filesin os.walk(root_name):

for file in files:

if m_list != '':

skip_flag= 0

if dir_flag== 1:

for dir in dir_list:

if (root+'/').startswith(root_name+ '/' + dir):

skip_flag= 1

break

if skip_flag:

continue

if file_flag== 1:

if file in file_list:

continue

pref= file.split('.')[0]

dir_pref= root+ '/' + pref

if file.endswith('.pyc'):

os.system('rm -f %s' % dir_pref+'.pyc')

elif file.endswith('.so'):

pass

elif file.endswith('.py'):

if operation== 'python3':

transfer3(dir_pref)

elif operation== 'python2':

transfer2(dir_pref)

else:

pass

except Exception as e:

print(e)

if file_name != '':

try:

dir_pref= file_name.split('.')[0]

if operation== 'python3':

transfer3(dir_pref)

elif operation== 'python2':

transfer2(dir_pref)

else:

pass

except Exception as e:

print(e)

if is_zip:

zip_dir(root_name,root_name+'.zip')

if operation== 'model':

encrypt_file(root_name)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值