网站首页 > 基础教程 正文
随着软件项目越来越多的商业化,代码保护的要求也会越来越高。目前主流的开发语言Python,由于动态语言的特性,在部署的时候通常采用源码部署。但实际项目运作,处于战略考虑,前期是不能直接给客户服务器上部署系统源码,因此在部署的时候需要采用各种方式避免源码暴露,我们称这个过程叫代码加密。
目前给代码加密的思路有混淆代码或者编译。
1、混淆策略就是将代码中的变量转换或者打乱,删除注释,增加无用的、错误的变量或者函数名来使代码变得混乱不易读懂,但是代码的结构一般不会发生变更。
2、编译的思路就是将py文件转换成二进制文件,在工程代码中经常能看到的就是__pycache__,此文件就是Python运行时编译后的一个文件夹。
此文件打开后也可以看到编译后的文件以pyc结尾,打开可以看到是一行行2进制代码(byte code)。是不能直观的阅读的。编译操作可以直接避免我们的代码泄露,而且还可以提高我们系统的执行速度。
还有一层优势是,pyc文件可以跨平台运行,因为它是有Python虚拟机来执行的。类似Java虚拟机的效果。
既然可以编译,那么反过来讲,pyc文件也是可以被反编译的,但不同版本编译后的pyc文件是不同的,根据Python源码中提供的opcode,反编译出py源码,我们可以修改opcode文件,重新编译py文件来防止被反编译。
下面我们看如何编译我们的代码:
python中有一个compileall模块,此模块可以将指定目录下的.py文件编译成python的二进制文件.pyc或者.pyo文件。
在我们安装完Python解释器后就是可以直接运行的。
例如:
python -m compileall "项目目录"
编译的速度很快,我测试使用的是4万行+的工程代码,几秒就可以编译完成。
若是不想改变目录结构,只将py文件编译成pyc,那么加入参数-b 即可。
python -m compileall -b "项目目录"
然后删除原来的py文件和__pycache__目录,若是不删除,那么工程在运行的时候还是会先执行py文件。
find ./ -name "*.py" |xargs rm -rf
find ./ -name “__pycache__” |xargs rm -rf
执行完后,系统就会调用pyc文件来运行。我测试使用的是Django工程,编译完在部署方面不需要做任何改动系统可以稳定运行。
- 上一篇: 用最简单的方式教会你使用Python正则
- 下一篇: Python必备技能大纲 python必学模块
猜你喜欢
- 2024-10-12 python代码是如何执行的? python的代码如何运行
- 2024-10-12 deepin os下使用Geany编写python程序
- 2024-10-12 扩展和嵌入 Python 之重定向输出与编译
- 2024-10-12 python爬虫数据匹配-正则(re模块的用法)
- 2024-10-12 Python中的.pyc文件是干什么的呢?
- 2024-10-12 解锁 Python 中的正则表达式:轻松搞定文本处理
- 2024-10-12 Python 的底层 — 解释器和内存管理,你了解多少
- 2024-10-12 python程序执行原理 描述python程序执行原理
- 2024-10-12 这些 python 技巧,不知道就 out 了
- 2024-10-12 “挑战用 500 行 Python 写一个 C 编译器”
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)