在实际的工做中,有时候咱们须要部署本身的Python应用,但这时候咱们并不但愿别人可以看到本身的Python源程序。所以,咱们须要为本身的源代码进行加密,Python已经为咱们提供了这样一套工做机制。python
第一种加密Python源代码的方式,是将.py文件转化为.pyc文件,但这种加密方式很容易被反编译,所以实用性并不高。工具
第二种加密Python源代码的方式,是将.py文件转化为.so文件,这样加密的可靠性很是高,没法被被人破解,也就很好地保护了源代码。测试
本文以Linux系统(Ubuntu)为例,讲解如何将本身的Python程序(.py文件)加密为.so文件。ui
首先,咱们须要在Ubuntu系统中安装一些准备工具,包括python3-dev,gcc,Cython,其中Cython为Python的第三方模块。安装的命令以下:加密
接着,咱们新建pythontest文件夹,用于测试咱们的代码,文件夹的内容以下:命令行
其中,mytest.py为咱们须要加密的Python程序,setup.py为加密的脚本。mytest.py的代码以下:blog
加密脚本setup.py的代码以下:部署
测试代码so_test.py的代码以下:编译
切换至pythontest文件夹,先运行so_test.py脚本(为了显示时间,便于跟后面的程序区分),再运行setup.py对mytest.py程序加密,命令以下:test
输出以下:
运行完加密命令行(python3 setup.py build_ext)后,文件夹中的文件以下:
在build文件夹中,有咱们须要的so文件,以下:
生成的so文件一方面对咱们的源程序进行了加密,另外一方面,咱们还能继续调用原来的mytest.py文件中的内容。为了验证此功能,咱们先删除mytest.py,再运行so_test.py文件,以下:
能够发现,咱们删除了mytest.py文件,即源代码,但so_test.py文件能够正常调用源程序的内容,这是由于,两次运行so_test.py的输出时间不同。
总结:在实际的工做中,咱们能够按照上面的方法将.py程序加密为.so文件,固然也能够写个脚本实现更复杂的功能。本次的文章仅做为展现,但愿可以给读者一些启发~