保护背景
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文件进行加密,加密操作完成后,程序可以正常运行。