🐰ELF x86 - Stack buffer overflow basic 1
Note : A JOURNEY TO GAIN KNOWLEDGE
Code chall:
Phân tích:
Lần lượt khai báo ba biến
var
,check
vàbuf
như vậy khi lưu trong bộ nhớ stack thứ tự:var
sẽ cao nhất sau đó đếncheck
và cuối cùng làbuf
Mục tiêu của ta là bypass được vế if thứ 2 để giá trị cửa biến
check
== 0xdeadbeefGiá trị ta có thể control được là buf, khi khai báo buff có giới hạn 40 kí tự tương đương với 40 bytes
Hàm fget cho phép ta nhập 45 kí tự vào buff tương đương 40 bytes cho buf và 5 bytes tràn, tuy nhiên ta chỉ nhập được 4 bytes kí tự còn lại chính là null
Ý tưởng và khai thác:
Như vậy ý tưởng lúc này chính là viết 40 bytes để chứa đủ biến buff sau đó truyền vào địa chỉ 0xdeadbeef
Đến đây có vẻ đúng hướng rồi, cuối cùng chuyển địa chỉ cần nhập sang little-endian là ok
Có thể dùng
pwntool
để đổi nhanh
Ý tưởng có vẻ đúng rồi, vấn đề lúc này shell đóng lại quá nhanh, do vậy ta thêm câu lệnh cat để duy trì shell và cuối cùng là cat flag
flag: 1w4ntm0r3pr0np1s
Last updated