Lua加密

两种方式:一种用luac,一种用luajit

luac加密:

1、lua本身可以使用luac将脚本编译为字节码(bytecode)从而实现加密,去官网下载Lua源代码包(http://www.lua.org/ftp/),下好解压,目录如下

2、启动一个Visual Studio 命令行工具,用32位命令行会生成32位版本,用64位则生成64位版本

3、在命令行中使用cd 进入lua目录(刚才解压后的目录),然后输入 "etc\luavs.bat" 回车

4、如果没有问题的话,会显示生成过程,(64位下还会有几个warning C4334)、完成后会在src目录下找到生成结果,4个主要文件一个.exp的中间文件,luac.exe生成完毕,

    然后把luac.exe所在存在的目录设为环境变量,如果不设置的话,那么执行生成字节码的dos命令的时候就要转到luac.exe所在的目录才能执行此dos命令了,都懂得,不多说

5、(1)、新建一个名为1.lua的文件,里面只有一句话print("Hello Lua"),新建一个空的out.lua脚本文件
    (2)、开始--运行--cmd
    (3)、luac -o out.lua 1.lua
      注: luac -o [编译后脚本名] [脚本名],必要时带上脚本路径,如:

然后实验一下,执行这个字节码脚本,可以看到lua原生的解释器可以直接解析luac编译出来的bytecode脚本,很方便!

luajit加密:

1、官网下载luajit(http://luajit.org/luajit.html),解压,目录如下

 

2、在命令行中使用cd 进入luajit下src的目录,然后执行输入msvcbuild.bat,执行此批处理文件,编译出luajit.exe

3、接下来就可以使用luajit.exe编译lua脚本的bytecode了:luajit -b [脚本名] [编译后的脚本名],执行完后会在src目录下生成一个已经编译成bytecode的lua文件

此时即使把此路径加入环境变量是没用的,进行luajit加密命令的时候必须使用cd进入此目录(C:\Users\hengjingjing\Desktop\LuaJIT-2.0.4\src),因为luajit加密,必须是luajit.exe和src下的jit文件夹配合使用才管用!

如果unity项目用的是基于ulua扩展的其他lua版本(cstolua、slua),或者本身用的就是ulua,那么要用luajit加密方式,因为ulua底层就是用的luajit

两者比较:

http://lua-users.org/lists/lua-l/2011-06/msg01052.html

LuaJIT is open source software, released under the MIT/X license.
LuaJIT builds out-of-the-box on most x86 or x64 operating systems
(Linux, Windows, OSX etc.) and can be cross-compiled for embedded
systems based on ARM or PPC/e500 CPUs.
The LuaJIT bytecode format is portable and ~40% smaller than Lua
bytecode. The LuaJIT bytecode loader is 10x faster than the Lua
bytecode loader. And LuaJIT bytecode loads 30x-40x faster than
source code. Note that this is unrelated to the _execution_ speed
of the code itself -- it doesn't matter how the code was loaded.

可以看出:Luajit跨平台,满足于32位和64位,并且加密后的bytecode比luac生成的bytecode至少小40%,速度也是它的10倍多,总之luajit就是比lua原生的好

 

转载于:https://www.cnblogs.com/MrZivChu/p/luaencryption.html

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个使用LuaSec库实现AES加密的示例代码: ```lua local aes = require("openssl.aes") -- 加密函数 function encrypt(key, data) -- 将key转换为128位的二进制数据 local key_bin = aes.digest("md5", key) -- 创建AES加密对象 local cipher = aes.new(key_bin, "CBC") -- 对数据进行PKCS7填充 data = cipher:pad(data, 16) -- 加密数据 local encrypted_data = cipher:encrypt(data) -- 返回加密后的数据 return encrypted_data end -- 解密函数 function decrypt(key, encrypted_data) -- 将key转换为128位的二进制数据 local key_bin = aes.digest("md5", key) -- 创建AES加密对象 local cipher = aes.new(key_bin, "CBC") -- 解密数据 local decrypted_data = cipher:decrypt(encrypted_data) -- 去除PKCS7填充 decrypted_data = cipher:unpad(decrypted_data) -- 返回解密后的数据 return decrypted_data end -- 测试代码 local key = "my_secret_key" local data = "Hello, world!" local encrypted_data = encrypt(key, data) print("加密后的数据:", encrypted_data) local decrypted_data = decrypt(key, encrypted_data) print("解密后的数据:", decrypted_data) ``` 这段代码使用了LuaSec库中的AES加密算法实现了加密和解密功能,其中encrypt函数用于加密数据,decrypt函数用于解密数据。加密过程中使用了CBC模式和PKCS7填充,解密过程中先解密数据,再去除PKCS7填充。在测试代码中,我们使用了一个字符串作为加密的数据,可以根据自己的需求修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值