文章目录
- 加密过程
- CompileScript加密函数
- 函数名称
- 函数语法
- 功能描述
- 函数参数
- 返回类型
- 返回值
- 示例
有时候我们希望保护所开发的ANSA二次开发python代码,需要对明文代码进行加密处理。而python是一门解释性语言,解释器可以直接阅读和执行代码。这意味着其源码无需编译即可运行,因此,代码常以人类可读的格式来显示。
为了保证代码的安全,需要将代码编译为仅机器可读的格式。app开发者可以使用加密技术将代码编译为二进制格式。
加密过程
为了编译代码,开发者需要在ansa或meta脚本编辑器内读取脚本。在菜单Project
下的Compile
选项可以输出代码为二进制的pyd扩展文件。
当点击Compile
按钮,一个额外的选项将出现,提醒用户选择是否以Pack Compilation Dependencies
方式编译。
如果用户没有勾选复选框,则编译过程将不考虑任何其他包的依赖,pyd文件仅仅包含主文件的代码。
另一方面,如果用户勾选按钮,pyd文件将不仅包含主文件的代码,还包含其他用ansa.ImportCode
函数导入的模块。
注意:
任何通过系统路径(sys.path)模块都不能导入到最终的二进制文件中,它通常被考虑为一个外部的依赖。
如下实例:
import ansa
import sys
import numpy
sys.path.append('my_functions')
import my_functions
from my_functions import *
ansa.ImportCode('my_library')
from my_library import shell_normal_vector
def foo():
pass
在上面的实例中,sys和numpy库不能被导入。my_functions
库也不能被导入。因为其是设置在系统路径中的。而且,所有4个库对于app都是外部库依赖 。如果用户选择Pack Compilation Dependencies
选项,my_library
模块将在最终的二进制文件中导入。
CompileScript加密函数
加密脚本可以采用ansa.CompileScript
函数来进行批处理。
函数名称
CompileScript - 从给定的脚本路径创建一个已编译的(pyb/bsx)文件。
函数语法
ansa.CompileScript(fileInput, fileOutput, moduleName, mode)
功能描述
从给定的脚本路径创建一个已编译的(pyb/bsx)文件。
函数参数
- [必填参数]] fileInput - 要编译脚本的路径字符串。
- [必填参数] fileOutput - 创建的编译文件的目标路径字符串。
- [必填参数] moduleName - 模块名字符串。
- [可选参数] mode(布尔值) - 仅对Python脚本有效。
- 在编译文件中包含脚本导入模块的选项。(仅当使用ansa.ImportCode功能导入时有效)
- True, 在已编译脚本中包含依赖项。(默认)
- False, 其他。
返回类型
整型
返回值
返回1表示成功,0表示失败
示例
import ansa
def main():
ansa.CompileScript("/home/user/scripts/some_script.py","/home/user/scripts/some_script.pyb","moduleName")
if __name__ == '__main__':
main()
警告
本文提供的加密方法是BETA CAE Systems开发的。不要和python编译器自动生成的字节代码文件pyc混淆。