常用的python加密方式
第一种加密Python源代码的方式,是将
.py文件
转化为.pyc文件
,但这种加密方式很容易被反编译
,因此实用性并不高。第二种加密Python源代码的方式,是将
.py文件
转化为.so文件
,这样加密的可靠性非常高,无法被被人破解,也就很好地保护了源代码。
本文以Linux系统(Ubuntu 18.04)为例,讲解如何将自己的Python程序(.py文件
)加密为.so文件
。
1 准备环境
1、我们需要在Ubuntu系统中安装一些准备工具,包括python3-dev
,gcc
,Cython
,其中Cython为Python的第三方模块。安装的命令如下:
$ sudo apt install python3-dev gcc
$ pip3 install cython
2、代码文件准备如下:
(base) shl@zhihui-mint:~/Disk2/3_proj$ tree CodeEncryption/
CodeEncryption/
├── setup.py # 把源码.py文件生成.so文件
├── so_test.py # 调用生成的.so文件
└── test.py # 要加密的源码文件
0 directories, 3 files
(base) shl@zhihui-mint:~/Disk2/3_proj$
2 调用Cython库包
把python的.py
文件生成.so
文件
先说一下大致流程:
1)写
源码.py文件
,我的源码写到test.py
2)把
源码 .py文件
生成.so文件
,使用上面的setup.py
3)调用生成
.so
文件,效果和调用源码是一样的,相当于只能调用接口
,但是并看不到源码的中的内容
下面说明具体操作:
2.1 写源码文件
源码文件为:test.py
import datetime
class Today():
def get_time(self):
print(datetime.datetime.now())
def say(self):
print("hello from SHL!")
我在源码中定义了:
- 一个
Today类
- 两个类方法:
get_time()
方法:获取当前时间say()
方法:打印输出一段字符
2.2 调用源码接口
so_test.py
中写的是调用源码
的接口,此时是从.py
的源码中直接调用的python代码!
1、so_test.py
调用接口代码:
(base) shl@zhihui-mint:~/Disk2/3_proj/CodeEncryption$ python so_test.py
2021-08-14 17:35:04.143138
hello from SHL!
(base) shl@zhihui-mint:~/Disk2/3_proj/CodeEncryption$
因为在执行python so_test.py
的时候,在so_test.py
文件中导入了from test import Today
,就会把test.py
模块先生成一个编译的.pyc
文件,目的就是在下次调用的时候加速,你可以删除,没有啥影响!
2.3 调用Cython库把.py
源码生成.so
文件
1、使用setup.py
脚本把源码test.py
生成.so文件
,setup.py
中定义内容:
from distutils.core import setup
from Cython.Build import cythonize
setup(ext_modules=cythonize(["test.py"]))
2、生成.so文件
:
python3 setup.py build_ext
生成之后的文件目录结构:
可以看到,生成了.so文件
,同时还生成了.c的源码文件
,以及.o
的中间代码文件,所以这个本质是把python代码转换为了C代码
,然后使用gcc工具进行编译!
3、把源码删除,然后通过so_test.py
接口调用.so文件
,先把.so文件
移到当前目录:
可以发现,此时依然可以通过.so
文件对test.py源码中定义的代码
进行调用,但是我们并不知道源码中具体的实现方式,因此实现了对.py源码文件的加密!
然后你就可以把源码删除
,其他没有用的文件也删除,然后只告诉别人.so
文件和调用接口
,这样保护了自己的源码
不被被人看到!你也可以以这种方式售卖自己的代码,后面优化更新源码还可以持续挣钱!