keras - 部署时如何隐藏或加密我自己的keras模型文件(如h5)?
问题描述
我为应用程序制作了自己的模型并将其保存在 Keras 中作为 .h5 文件。我使用 PyQt5 制作了 GUI 应用程序,这个应用程序使用了这个模型。我正在尝试在没有任何有关深度学习模型的信息的情况下部署此应用程序。我对这种情况有一些疑问。
- 我可以隐藏或加密我的模型以防止其架构和重量暴露吗?
- 如果 Keras 不支持加密模型,是否还有其他支持此功能的库(如 PyTorch)?
我期待听到任何建议。谢谢您的回答。
解决方案
模型加密不是正式的keras
一部分pytorch
。
如果你想隐藏一些东西,我认为 Python 是一个大问题。AFAIK 使用它来隐藏你的解决方案是不可能的,我将概述我将如何“保护”模型(这些很长,所以请确保你真的需要这种保护[或确切的保护级别]) .
提供Python解决方案
存在处理PyTorch和 Keras 的 PySyft,但它用于安全多方计算。由于用户可以访问您的 Python 代码(您提到了 PyQT5)和所有敏感数据(在本例中为模型),他们将能够很容易地恢复它。
可能的解决方案
如果我是你,我会选择简单的受密码保护的存档(AES 或.zip
)。对于第一种情况,我找到了这篇文章和相关的TFSecured 存储库,它通过 Python 对 tensorflow 模型进行 AES 加密,并允许您在 C++ 中加载保存的加密 protobuf 模型文件(这应该是您的方式,原因如下)。
别管 Python
您是否想认真保护您的模型(不仅仅是某种混淆),您根本不应该在用户端使用 Python。
没有办法编译 Python 的代码,尤其是使用 Keras、Tensorflow 或 PyTorch 等重型 ML 库的代码。尽管有像PyInstaller这样的程序,但众所周知,要让它与复杂的依赖项一起工作是非常困难的。即使你这样做了,用户仍然可以访问代码,尽管它可能会有点困难(PyInstaller 只是将 Python、你的依赖项和应用程序捆绑为一个存档,稍后会解压缩)。
您可以使用pyarmor或类似的东西进一步混淆代码,但如果有人下定决心,这一切都很容易逆转。
C++
无论您选择keras/tensorflow
还是pytorch
可以使用较低级别并使用 C++ 来加载您的网络。
由于它是一种编译语言,您所要做的就是提供一个二进制文件(如果是静态链接)或带有共享库的二进制文件。在 C++ 源代码中,您保留 AES/zip 密钥,如博客文章所示TFSecured
:
#include <GraphDefDecryptor.hpp>
........
tensorflow::GraphDef graph;
// Decryption:
const std::string key = "JHEW8F7FE6F8E76W8F687WE6F8W8EF5";
auto status = tfsecured::GraphDefDecryptAES(path, // path to *.pb file (encrypted graph)
graph,
key); // your key
if (!status.ok()) {
std::cout << status.error_message() << std::endl;
return;
}
// Create session :
std::unique_ptr<Session> session(NewSession(options));
status = session->Create(graph);
对已编译的 C++ 代码进行逆向工程以获取隐藏在其中的密钥要困难得多。PyTorch
也可以通过一些第三方工具/库来完成类似的过程。另一方面,您必须使用 Qt5 在 C++ 中重写您的 PyQt5 应用程序。
推荐阅读
- python - AioHTTP 服务器 - 当前服务了多少飞行中的请求
- php - 如何在具有元素 id 的 Yii2 GridView 中存储所需表中的值?
- html - 如何使用 CSS 仅在图像的一侧设置溢出隐藏并同时保持响应?
- python - Python中内核回归的权重向量
- cassandra - Cassandra-quarkus-client 在 quarkusCqlSession.prepare 挂起
- python - 根据 dateTime 创建子组
- flutter - 如何在颤动的第一行文本之前添加竖线?
- excel-formula - 前几个季度的excel公式
- html - 如何删除样式
- javascript - ag-grid 打印不适用于自定义渲染的单元格(使用“cellRenderer”)