-
Notifications
You must be signed in to change notification settings - Fork 44
/
README
48 lines (32 loc) · 1.4 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
AES for lua
-----------
This files contain an implementation of AES in lua. The only additional library
needed is bitlib.
Usage
-----
aeslua.lua contains a simple API to encrypt and decrypt lua strings.
To encrypt the string "geheim" with the password "password" use:
require("aeslua");
cipher = aeslua.encrypt("password", "secret");
and to decrypt the string again:
plain = aeslua.decrypt("password", cipher);
You can also specify the key size and the encryption mode. For further examples
look into the file src/testcryptotest.lua.
To use AES directly, have a look at aes.lua and at the example usage in
testaes.lua.
Installation
------------
Edit the LIBDIR variable in the Makefile and run
make install
Speed
-----
The implementation is rather optimized (it uses tables for most AES operations)
but still cannot compete with AES written in other languages. Typical AES
implementations reach several 100 MBit per second, this implementation only
reaches 400 kBit per second. The most plausible reason is the heavy reliance
of AES on bit operations. As lua numbers are doubles bitlib needs to convert
them to long values for each bit operation.
So if you need to encrypt much data with AES, do yourself a favor and use a
C-Implementation. But if you only need to encrypt short strings and you have
no control over the lua environment (like in games :-)) use this library.
Matthias Hilbig <[email protected]>