python加密方式
人气:0Python的文件类型介绍:
- .py python的源代码文件
- .pyc Python源代码import后,编译生成的字节码
- .pyo Python源代码编译优化生成的字节码。pyo比pyc并没有优化多少,只是去掉了断言
- .pyd Python的动态链接库(Windows平台)
- .so
常见的源码保护手段有如下几种:
1.发行.pyc文件
pyc文件是py文件经过编译后生成的二进制文件,python提供py_compile内置模块把py文件编译为pyc文件,得到的.pyc文件可以直接运行python xxx.pyc
.pyc只能在特定版本的解释器上运行
1.1 编译加密
mian.py
def spread(arg): ret = [] for i in arg: if isinstance(i, list): ret.extend(i) else: ret.append(i) return ret def deep_flatten(lst): result = [] result.extend( spread(list(map(lambda x: deep_flatten(x) if type(x) == list else x, lst)))) return result print(deep_flatten([1, [2], [[3], 4], 5]))
编译指令:
python -m py_compile main.py
python -m compileall main.py
批量
1.2 是否可逆
- pyc加密现成的反编译工具,可以反编译得到源代码.
- 使用uncompyle库进行反编译
可逆
测试:
pip install uncompyle uncompyle6 main.cpython-38.pyc > main.py
1.3是否影响模块调用
不影响使用
# coding=utf-8 # 调用模块main from main import deep_flatten print(deep_flatten([1, [2], [[3], 4], 5]))
2.代码混淆
- 1.1 降低代码可读性
- 1.2 不影响模块之间调用
3.生成exe可执行文件
使用py2exe
py2exe是将Python代码转换为 Windows 平台上的可执行文件的工具,只能在windos上使用,原理是译为 .pyc 文件,加上一些动态连接依赖文件,一起打包成一个可执行文件。
pip install py2exe
需要编写setup.py文件:
#!/usr/bin/env python from distutils.core import setup import py2exe setup(console=[f'E:\_Py_Project\leanPy\work\代码加密\main1.py'])
然后执行 python setup.py py2exe
- 1.1 是否可逆
不可逆
- 1.2 是否影响模块调用
不影响
4…py文件转化为.so文件
生成使用 Cython
它的原理:将 .py/.pyx 编译为 .c文件,再将 .c文件编译为 .so(Unix) 或 .pyd(Windows)
pip install Cython
setup.py
from distutils.core import setup from Cython.Build import cythonize setup(name='main1', ext_modules=cythonize(f'E:\_Py_Project\leanPy\work\代码加密\main1.py'))
python setup.py build_ext
在windos下生成.pyd文件
测试 .pyd文件,把mian1.py删除,把.pyd文件移动到.py原来目录下
在linux下生成.so文件
测试:
- 1.1 是否可逆:
不可逆
- 1.2 是否影响模块调用
不影响
5.附加运行辅助包文件
pip install pyarmor==6.8.1
pyarmor obfuscate main.py
同目录下所有的 *.py文件都会被加密
方式一:高级加密模式,需要引导代码
方式二:超级加密模式
超级模式只需要一个运行辅助文件,没有了所谓的引导代码
pyarmor obfuscate --advanced 2 .\main1.py
方式三: 虚拟加密模式
高级 + 虚拟
pyarmor obfuscate --advanced 3 .\main1.py
超级 + 虚拟
pyarmor obfuscate --advanced 4 .\main1.py
辅助文件和编译文件
几种加密方式对比:
加载全部内容