Lock python 加密、混淆、打包、权限算法程序,作为一个知识产权,要注意把它保护起来,当你绞尽脑汁实现的算法要交付给甲方爸爸使用的时候,首先要考虑的是将它加密起来,告诉别人,他只有使用权哦! 当然,也有可能是不想让别人发现自己的代码写的有多烂~
根据加密难度、调用难度、解密难度综合由易到难排序,主要介绍以下四种加密和混淆的方式、特点以及它们加密后的调用方式。
1、编译为pyc文件****2、将py文件混淆****3、打包为exe文件****4、编译为pyd文件python程序一般独立调用的方式为在安装有python环境的终端CMD运行:
> python xxx.py 参数1 参数2...
01
将py文件编译为pyc文件
-
加密方式
将py文件路径下的所有py文件编译为pyc文件,在控制台运行:>python -m compileall py文件路径运行结束后会在目录下生成一个pycache文件夹,保存生成的全部pyc文件:
编译后的pyc文件不具备可读性:
-
调用方式
调用方式与python单独调用方式一致:>python xxx.pyc 参数1 参数2...
-
优缺点
加密简单、方便,平台兼容性好,py能运行的地方,pyc就可以运行;但反编译容易,易于破解,保密性不足。
注:文件名不可用中文
02
将py文件混淆
-
混淆方式
http://pyob.oxyry.com/ 是一个在线混淆代码的网站,用它可以方便地混淆:
-
调用方式
调用方式与python单独调用方式一致:>python xxx_HX.py 参数1 参数2...
-
优缺点
简单方便,稍微提高了一点源码破解门槛;但只能对单个文件混淆,代码结构未发生变化,也能获取字节码进行破解。
03
将py文件打包为exe
-
加密方式
首先需要安装pip install pyinstaller,通过pyinstaller将py文件和它依赖的包一起打包为可执行的exe;对于Linux,操作方式一致,只打包好的文件没有后缀名。
在控制台运行:
>pyinstaller -F D:\xxx.py
执行完成后,会生成build和dist文件夹,exe文件就保存在dist文件夹下。
注:exe文件的一个问题是它将所有有用和无用的依赖包都打包进去,导致exe文件较大,影响运行效率,所以建议搭建python虚拟环境,删除pip list中不必要的依赖包,减小exe大小。可以参考https://blog.csdn.net/qq_40623536/article/details/106449039
-
调用方式
不需要加python,直接在Windows控制台运行:
xxx.exe 参数1 参数2...
Linux方式一致:$ xxx 参数1 参数2...
-
优缺点
方便运行,不要求设备部署安装python环境,也较难破解;但如果算法程序复杂,打出来的exe包体积较大。
04
将py文件编译为pyd文件
-
加密方式
需要在py文件同目录下编写setup.py:
然后在当前目录打开控制台运行:
python setup.py build_ext –inplace
执行结束后在当前目录生成c文件和pyd文件:
-
调用方式
调用方式比较麻烦,举个栗子:
一个sss.py中包含hello()这个函数,设置参数s为sds
python -c "from sss import hello;hello('sds')"
输出:sds
-
优缺点
pyd文件难以破解,运行性能有提升;但对于不同版本的操作系统,可能需要重新编译。