您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Lua v5.4.0及之前版本lsys_load()棧溢出漏洞的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
Lua是一種輕量小巧的腳本語言,用標準C語言編寫并以源代碼形式開放。
Lua v5.4.0 及之前版本lsys_load()函數加載動態鏈接庫時沒有正確處理文件名的長度,造成棧溢出漏洞,可造成拒絕服務問題。
Lua <= v5.4.0
$ git clone https://github.com/lua/lua.git $ make $ ./lua ./Stack_overflow_lsys_load.lua AddressSanitizer:DEADLYSIGNAL ================================================================= ==90451==ERROR: AddressSanitizer: stack-overflow on address 0x7ffc56ae1e38 (pc 0x7f84c442acf7 bp 0x7ffc573773f0 sp 0x7ffc56ae1e40 T0) #0 0x7f84c442acf6 (/lib64/ld-linux-x86-64.so.2+0x7cf6) #1 0x7f84c442cd4d (/lib64/ld-linux-x86-64.so.2+0x9d4d) #2 0x7f84c44379c3 (/lib64/ld-linux-x86-64.so.2+0x149c3) #3 0x7f84c31d148e in _dl_catch_exception (/lib/x86_64-linux-gnu/libc.so.6+0x15c48e) #4 0x7f84c44372c5 (/lib64/ld-linux-x86-64.so.2+0x142c5) #5 0x7f84c34a9255 (/lib/x86_64-linux-gnu/libdl.so.2+0x1255) #6 0x7f84c31d148e in _dl_catch_exception (/lib/x86_64-linux-gnu/libc.so.6+0x15c48e) #7 0x7f84c31d151e in _dl_catch_error (/lib/x86_64-linux-gnu/libc.so.6+0x15c51e) #8 0x7f84c34a9a24 (/lib/x86_64-linux-gnu/libdl.so.2+0x1a24) #9 0x7f84c34a92e5 in dlopen (/lib/x86_64-linux-gnu/libdl.so.2+0x12e5) #10 0x7f84c36c9a33 (/usr/lib/x86_64-linux-gnu/libasan.so.5+0x8ea33) #11 0x56529c0e5908 in lsys_load /home/test/Lua/Test_lua/lua/loadlib.c:134 #12 0x56529c0e5908 in lookforfunc /home/test/Lua/Test_lua/lua/loadlib.c:391 #13 0x56529c0e5a14 in ll_loadlib /home/test/Lua/Test_lua/lua/loadlib.c:412 #14 0x56529c09025c in luaD_call /home/test/Lua/Test_lua/lua/ldo.c:481 #15 0x56529c0b8824 in luaV_execute /home/test/Lua/Test_lua/lua/lvm.c:1614 #16 0x56529c0b8824 in luaV_execute /home/test/Lua/Test_lua/lua/lvm.c:1614 #17 0x56529c090605 in luaD_callnoyield /home/test/Lua/Test_lua/lua/ldo.c:525 #18 0x56529c08dc51 in luaD_rawrunprotected /home/test/Lua/Test_lua/lua/ldo.c:148 #19 0x56529c0911e0 in luaD_pcall /home/test/Lua/Test_lua/lua/ldo.c:749 #20 0x56529c086f8f in lua_pcallk /home/test/Lua/Test_lua/lua/lapi.c:1031 #21 0x56529c08042a in docall /home/test/Lua/Test_lua/lua/lua.c:139 #22 0x56529c08179d in handle_script /home/test/Lua/Test_lua/lua/lua.c:228 #23 0x56529c08179d in pmain /home/test/Lua/Test_lua/lua/lua.c:603 #24 0x56529c09025c in luaD_call /home/test/Lua/Test_lua/lua/ldo.c:481 #25 0x56529c090605 in luaD_callnoyield /home/test/Lua/Test_lua/lua/ldo.c:525 #26 0x56529c08dc51 in luaD_rawrunprotected /home/test/Lua/Test_lua/lua/ldo.c:148 #27 0x56529c0911e0 in luaD_pcall /home/test/Lua/Test_lua/lua/ldo.c:749 #28 0x56529c086f8f in lua_pcallk /home/test/Lua/Test_lua/lua/lapi.c:1031 #29 0x56529c07fbda in main /home/test/Lua/Test_lua/lua/lua.c:629 #30 0x7f84c309909a in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x2409a) #31 0x56529c080239 in _start (/home/test/Lua/Test_lua/lua/lua+0x18239) SUMMARY: AddressSanitizer: stack-overflow (/lib64/ld-linux-x86-64.so.2+0x7cf6) ==90451==ABORTING ```
漏洞發生在package.loadlib函數中,當用package.loadlib加載一個名字很長的動態鏈接庫時,造成棧溢出:
static void *lsys_load (lua_State *L, const char *path, int seeglb) { void *lib = dlopen(path, RTLD_NOW | (seeglb ? RTLD_GLOBAL : RTLD_LOCAL)); ---->crash if (lib == NULL) lua_pushstring(L, dlerror()); return lib; }
在加載動態鏈接庫時限制動態鏈接庫的長度。
關于“Lua v5.4.0及之前版本lsys_load()棧溢出漏洞的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。