使用仅有的 C 代码安全地执行任意 Lua 代码
2017-12-31 5:14:21
收藏:0
阅读:101
评论:2
我知道你可以通过使用 Lua 函数 setfenv 来 安全地执行 Lua 中的任意代码,但如果我通过脚本来执行该操作,不仅会变得凌乱不堪,而且(用户可修改的游戏中),一个不知情的用户在将 mod 安装到文件夹中时可能会不加思索地点击“全部替换”或其他按钮。我确定还有其他更容易绕过这种方式的方法。
总体上,最安全的方法应该是使用直接的 C 调用,没有涉及设置沙盒的 Lua 代码/字符串。我该怎么做呢?
点赞
用户6892231
任何你在 Lua 脚本中编写的代码都可以通过 Lua C API 在 C 中执行。但是,在 C 中跟踪等价的 Lua 脚本要更加困难。当我想要为主机程序编写一些受保护的 Lua 脚本时,我的做法通常有:
- 把它们放在一个独立的目录中。
- 将它们加密成只有我的 C 程序知道私钥的存档文件。
- 将它们作为多行字符串嵌入到 C 源代码中。
- 将编译后的脚本作为二进制字符串嵌入到我的 C 源代码中,以防止它们通过程序的 exe 二进制编辑轻易被盗用。(有时,我使用脚本的 SHA 值来防止它们在程序内部被编辑) …等等。
你绝对需要使用沙盒来保护运行游戏的计算机免受恶意脚本的攻击。例如不允许访问文件系统。但要注意,要想完全保护主机程序免受各种恶意脚本(例如通过 while 1 循环挂起游戏的 Lua 实例线程,或是巨大的内存使用量,复杂的字符串匹配调用等等)的攻击,您需要做更复杂的工作,并向 mod 脚本提供更多的约束条件。
例如,即使是 while 1 do end 也会导致魔兽争霸的用户界面发生挂起。
希望这会有所帮助。
2018-01-12 09:08:42
评论区的留言会收到邮件通知哦~
推荐文章
- Lua 虚拟机加密load(string.dump(function)) 后执行失败问题如何解决
- 我想创建一个 Nginx 规则,禁止访问
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?

只是不要使用
luaL_openlibs。另一个选项是在你的C程序中将一些Lua代码存在一个字符串或字节码中,在任何其他操作之前执行它。