保护背景

Python语言写的程序无需编译成二进制文件代码,可以直接从源代码运行程序。在计算机内部, Python解释器把源代码转换成字节码的中间形式,然后再把它翻译成计算机使用的机器语言并运行,这使得 Python程序更加易于移植。

支持范围

若不符合以下列表中场景的用户,可以联系深思客服详细咨询。

场景是否支持
Anconda2/Anconda3支持
C++/C语言文件中调用python支持
py文件中调用C++/C支持
pyinstall/py2exe将py文件打包成exe支持
py文件转成的pyd/SO/可执行文件支持

对.pyc或者.py文件进行保护

1 . 查找Python.exe

运行python程序,可在任务管理器中查找py/pyc文件调用的主进程。


2. 对python.exe 进行加密。

对安装环境 Python 路径下的 python.exe 进行加密。

将 python.exe 拖入到加壳工具Virbox Protector 中。

配置加密选项
将加密选项中的 DS 开关打开,并设置密码。
【一般情况下,密码可随意设置(随机生成,已经过加密处理),不需要记忆】


点击“保护选中项目”,加壳后会额外生成图示两个文件。

python.exe.ssp 是配置文件,在后面对 .py/.pyc 加密时会用到;python.ssp.exe 是加壳后的 python.exe 文件,将 python.exe 剪切到其他文件夹备份,python.ssp.exe 名字改为python.exe 即可。

3. 对 .py/.pyc进行保护

打开“DSProtector.exe”对 .py/.pyc进行保护。

添加上一步加密 python.exe 生成的 python.exe.ssp 文件。添加要加密的 .py/.pyc文件。


点击“开始保护”,加密成功。

加密后的文件名为源文件名称,.bak 文件为自动备份的源文件,软件发布前需删除bak 文件。

如果不想在当前目录生成bak文件,可先设置默认输出目录,会将加密后的资源文件输出到设定的目录


至此,Python 的 .pyc /py文件已经加密成功。

pyinstall/py2exe打包exe加密流程

场景:在Windows系统上,使用python自带打包工具pyinstall/py2exe将py文件打包成单个exe。应该怎样保护?

以python3.5/pyinstall为例,操作如下:

【注意】以下两种方案均不能避免exe运行产生临时文件的情况。

方案一

针对pyinstall或py2exe将py文件打包成的exe程序,可以直接使用Virbox Protect工具对exe文件进行加壳保护。

  • 优点:方便,快捷。
  • 缺点:由于exe运行会产生临时文件(Virbox Protect工具只对exe进行保护并不会改变exe的功能),可以通过监测exe找到缓存文件的位置,获取未加密文件。

方案二

pyinstall打包时会将python35.dll库打包到exe中,且python.exe依赖python35.dll。

  • 优点:产生的临时文件中的python35.dll是保护过后的,相对方案一较安全。
  • 缺点:操作流程相对方案一较复杂

1、使用Virbox Protector工具对python35.dll进行加壳保护。

2、DSProtector对py/pyc文件进行加密,加密操作完成后,使用pyinstall打包exe。


C++文件中调用python文件

场景:在Windows系统上,使用C++语言的文件中调用py文件,将C++文件打包成exe后,应该如何保护?

以python3.7为例:

1、使用Procmon.exe查看打包后的exe运行所依赖的文件,可以看到是python37.dll。

2、然后使用Virbox Protector工具对python37.dll进行加壳,使用DSProtector对py文件进行加密,加密操作完成后,即可操作运行。

如何加密Linux部署的python程序

场景:直接命令行中运行python文件。

1、命令行直接执行py或pyc文件,比如:python demo.py或python demo.pyc。

2、查找py/pyc文件调用的主进程。

3、找到主进程后,再依次使用Virbox Protector工具对主进程加壳,DSProtector对py/pyc文件进行加密,加密操作完成后,程序可以正常运行。