Basic Buffer Overflow - VulnServer TRUN

Поділитися
Вставка
  • Опубліковано 23 січ 2025

КОМЕНТАРІ • 234

  • @signum42
    @signum42 4 роки тому +58

    Fantastic video. Appreciating the "slow pace"

  • @mattstorr
    @mattstorr 3 роки тому +76

    This is by far the simplest and logical walkthrough of buffer overruns and how to exploit them that I've seen. I really appreciate the pace (I dont care that it was long) as you covered each part. I understood everything except the struct and little endian elements. I guess I have some reading to do :-)

    • @martinndzelen88
      @martinndzelen88 3 роки тому

      same here i got lost around there

    • @jonaskoelker
      @jonaskoelker 3 роки тому +15

      Little vs. big endian, two minute edition: when you write numbers, like 123 (= 1*100 + 2*10 + 3*1), you write the 3 in the ones place last, and the 1 in the biggest place (here 100s) first. That's big endian. If you write the ones place first and the biggest place last, e.g. write 321 to mean 3*1 + 2*10 + 1*100, that's little endian.
      The particular number we're looking at in the code, 0x62501203, is currently in big endian. What the particular step is about is converting it to a 4-digit base-256 number written in little endian (in python's `bytes` type).
      If you just want to do the conversion by hand, from int to int, you can just put in 0x03125062. Notice how each pair of hex digits has been swapped by its opposite: first and last swap, and the middle two swap. Each pair of hex digits corresponds to a single digit in base 16*16 = 256.
      Python v3.2 and newer has a `.to_bytes` method on int objects, so you could also do `(0x62501203).to_bytes(4, byteorder='little')` and get the desired result.

    • @derekrickmon5316
      @derekrickmon5316 3 роки тому +2

      You don't understand something until you can explain it simply.

  • @fhajji
    @fhajji 3 роки тому +8

    Love the slow pace and crystal-clear explanations. Easy to understand and follow.

  • @kameronwilliams723
    @kameronwilliams723 3 роки тому +6

    The way you broke that down to where a complete beginner like myself could grasp it is a real talent.

  • @collapzcursed
    @collapzcursed 3 роки тому +6

    Came in here with very minimal (to non-existent) understanding of bytecode and memory-buffers ... just let me say that you did an absolutely amazing job at explaining the whole of it and how each aspect works and interacts with each other.
    All of that in just about an hour. "Slow pace", yeah right.
    You're a great teacher and a real blessing for those willing to learn.
    I've watched a few CTF videos and miscellaneous stuff of yours but after this one you got yourself that +1 "plzsub" :D!
    Keep up the great work, John!
    It is greatly appreciated.

  • @tomsite2901uk
    @tomsite2901uk 2 роки тому

    This is by far the best video i ever saw regarding buffer overflows and how to exploit them. This is a must see for every security researcher.

  • @atharvakadlag1937
    @atharvakadlag1937 3 роки тому +1

    Now that i have spent weeks understanding buffer overflow, everyone has started making awesome videos on that topic

  • @adminservice9459
    @adminservice9459 4 роки тому +5

    You're an awesome instructor, I commend you for humbling yourself and breaking everything down in simple terms vs your knowledge level lol. Thx man

  • @AvinashKumar-fe8xb
    @AvinashKumar-fe8xb 2 роки тому

    love you john hammond, I learned so much feel like i should dive more into buffer overflow after practically doing it myself along with you. Thank you!

  • @liquathrushbane2003
    @liquathrushbane2003 4 роки тому +2

    Beginner here - not sure why you built the nop_sled, but the rest of it made perfect sense. Thank you.

    • @avananana
      @avananana 4 роки тому

      I'm no genius but as far as I know, nop sleds are used to guide the program to execute code when you don't know exactly where the code lies but you know the rough area. In this case you knew exactly where to go so the nop slide was indeed kind of useless, but I do believe he brought it up only so we could know it's a thing.
      The reason your malicious code could lie somewhere else in the system is if it didn't fit inside the initial payload, where the code itself is another payload and ended up going somewhere else in the system. A way to reach the code is by putting a long nop slide infront of it and initiating a jmp instruction somewhere inside the nop slide. This way you don't have to know where the code lies, only roughly where it is.

  • @HaouasLeDocteur
    @HaouasLeDocteur 3 роки тому

    I can’t believe I just sat through a 1h video and it was the greatest thing I’ve seen all day. Loved, loved it!

    • @pdemosllegaralos520subs2
      @pdemosllegaralos520subs2 3 роки тому

      Really enjoyed it, I tried this once prior to watching this and realized where I stuffed up. (little endian addr), the mona script helps ALOT.. thanks.

  • @danielallan3417
    @danielallan3417 3 роки тому

    Unreal mate, I rarely comment but you have imparted your knowledge with exceptional skill!! I absorbed it all so easily!!! Awesome.

  • @krist81
    @krist81 2 роки тому

    Thank you. The way you explained and demonstrated everything made so many different pieces finally come together for me. Ty

  • @emT__T
    @emT__T 3 роки тому +2

    Thank you John for the great video. Super Informative! The "beginner" approach is much appreciated.

  • @geraldfranzmaliwanag
    @geraldfranzmaliwanag Рік тому

    Thank you so much for this tutorial. You have explained it very clearly and easy to follow. Buffer overflow is the topic that made me think twice to continue pursuing cybersecurity. But there you are. Life saver. Dream Saver! Thank you so much for this tutorial.

  • @cortisolblue2208
    @cortisolblue2208 2 місяці тому

    This unfolded like a movie I got more and more invested as time went on.

  • @saurabhshinde1855
    @saurabhshinde1855 3 роки тому

    Most simple and comprehensive walkthrough of buffer overflow.. Really liked and understood it.. keep it up john

  • @theITGuy-no3nt
    @theITGuy-no3nt 3 роки тому +2

    I have watched a ton of your videos over the past few week, but this is my favorite. Watching you work through that was super instructive and downright entertaining. ⭐⭐⭐⭐⭐

  • @kapalov
    @kapalov 4 роки тому +1

    Finally, the only video where it really clearly explains about BoF. Thanks

  • @aaronw6195
    @aaronw6195 3 роки тому +1

    This may have been one of the best videos I've ever seen on how to exploit a buffer overflow. The technique of writing the code from scratch to do this in python was super helpful! Thanks John!

  • @ronorocky
    @ronorocky 3 роки тому

    from couple of weeks i was searching for some good practical for buffer overflow, and seriously man u made it so easy with the python script, the end was awesome when you get the meterpreter, love u man ❤️ keep doing this gr8 work.

  • @nicklevson9608
    @nicklevson9608 4 роки тому +1

    This was the most in depth explanation I have seen so far. Thank you!

  • @ping9940
    @ping9940 3 роки тому

    i dont know any thing about this and i was hooked for the whole video this was an amazing explanation i felt like im understanding every thing thou i'll forget all of it by the next hour :D

  • @moonshiry
    @moonshiry 3 роки тому

    You are amazing my dude, I love how you really went step by step and didn't gloze over anything. Especially the programming and immunity debugger parts. (which is practically everything). This teaching style trumps university professors

    • @bmbiz
      @bmbiz 3 роки тому

      Please refrain from using the word "trump(s)". It triggers my PTSD. ;)

    • @ldSt3345
      @ldSt3345 3 роки тому

      @@bmbiz please refrain from writing such terrible comments. It triggers my triggerinator.

    • @skreet7251
      @skreet7251 3 роки тому +1

      @@ldSt3345 please refrain from being a bub it triggers my bob

  • @Cyberducky
    @Cyberducky 3 роки тому

    I recently fell in love with your videos. I'm still a student but I hope that one day I'll have such a deep understanding as you have.

  • @KieCodes
    @KieCodes 4 роки тому +1

    That was an amazing video. It really helped that you created everything by hand without using too many tools to shorten the process. Thanks a lot!

  • @KaranveerSingh97
    @KaranveerSingh97 3 роки тому

    Well, understanding computer architecture is super important for understanding and making these exploits. Great video!

  • @GaryFrancis-q3r
    @GaryFrancis-q3r 3 роки тому +1

    What you manage to do is insane... it seems almost magic. Thanks for sharing. Hope to see other exploits like this (using buffer overflow). Cheers!

  • @dopy8418
    @dopy8418 4 роки тому +16

    Pretty cool diversity of clips. Can’t wait for some more koth.

  • @bbowling619
    @bbowling619 3 роки тому

    Its a super fast pace for me but i keep grabbing onto the handle bars everytime he posts and am fully enjoying this circus ride :)
    I genuinely cant get enough.
    Please be my boss John !?
    I would literally enjoy having you boss me around (not in a wierd way) but i want to sponge you.
    No i did not say spoon you hahah :)
    Your teaching skills are super amazing but your brain is the jam!
    Totally digging your skills dude.

  • @normanalc3115
    @normanalc3115 4 роки тому +15

    You're legend mate! I learned a lot from this video. You've explained it very well 5 star for you 🌟🌟🌟🌟🌟

  • @padaloni
    @padaloni 4 роки тому

    This is a really good explanation of how to do the BOF on certain exams. I already knew how to do this, but I learned a few things on the way. love your work bro

  • @aymenahdibi1251
    @aymenahdibi1251 4 роки тому +1

    Awesome john i really love your content . never got bored watching your videos till the last second
    Keep up the good work ★

  • @TheHangman1995
    @TheHangman1995 3 роки тому +1

    This and TCMs buffer overflow are my go to when I need to do BOFs

  • @mathieul695
    @mathieul695 2 роки тому

    Tip, you can use python to generate a list of 2984 different 4*characters by using random and a dictionary to retrieve it. Great Video John, keep it up

  • @Foxy10-b6n
    @Foxy10-b6n 2 роки тому

    Tremendous help and fantastic write up, worked perfectly!

  • @chrishammer5925
    @chrishammer5925 4 роки тому

    Perfecto... I learned Buffer Overflows once 5 months ago and taking my OSCP soon. About to jump into these again to do over and over for the test. Perfect timing mate!

  • @farouqseriki5942
    @farouqseriki5942 2 роки тому

    Hello, i had spent hours searching for a fix that would work for python3, then i found this video. Thanks so muchhhhhh

  • @oscpjourney541
    @oscpjourney541 4 роки тому +5

    I can't say BIG THANK enough I have watched many videos about this BOF but this one one I get some hints Be blessed John

  • @glennbogaerts7914
    @glennbogaerts7914 4 роки тому +1

    This was a very clear and well explained video. Great job John

  • @HuntingKingYT
    @HuntingKingYT 3 роки тому +14

    Tip: you can use the instruction int3 (0xCC) to make a debug breakpoint, then you can see much faster when the exploit occurs.

  • @stuarthook6226
    @stuarthook6226 3 роки тому

    Thanks so much for this video. I was able to do BOF very easily after your video.

  • @CondorrK
    @CondorrK Рік тому

    This was a fun watch, since i had little knowledge of Fuzzing or buffer overflow i didnt know they were related, but oberflow does kinda work how i thought. Now i have something else to mess with and try to practice 😂

  • @aaaaaaaaaaaaaaaaaaaaaaaa997
    @aaaaaaaaaaaaaaaaaaaaaaaa997 2 роки тому

    Great video. Thanks for the slow pace.

  • @jorgevilla6523
    @jorgevilla6523 4 роки тому

    Wow great Video!! Love the slow pace and explanation.

  • @Novastuffnow
    @Novastuffnow 4 роки тому

    I still don't fully understand buffer overflows but I'm way closer now, thank you!

  • @jacks16384
    @jacks16384 3 роки тому

    Really enjoyed it, I tried this once prior to watching this and realized where I stuffed up. (little endian addr), the mona script helps ALOT.. thanks.

  • @swyveu
    @swyveu 2 роки тому

    blown away... and great teaching skills !

  • @AC-dw8cs
    @AC-dw8cs 3 роки тому

    i wish i found your channel sooner. GJ!

  • @Construction-agencyCoUk
    @Construction-agencyCoUk 3 роки тому

    Woah! watched the whole video and learned alot ! Thanks John

  • @AFchump78
    @AFchump78 4 роки тому +1

    Thanks alot John! I was able to do it and this should help with the upcoming eCPPT retake. It was down to the wire and i couldnt connect with the one i built. See the mistakes now.

  • @pinglollo6283
    @pinglollo6283 3 роки тому

    Awesome video John, great explanation and demonstration. thanks for uploading.

  • @anuragyelala6952
    @anuragyelala6952 3 роки тому

    Fantastic! thank you John, so many bits and pieces are clarified with your video.

  • @saurabhkumar1976
    @saurabhkumar1976 3 роки тому +1

    Thank you for this video , i learnt a lot 🙂

  • @adamkadaban
    @adamkadaban 4 роки тому +4

    The beard looks absolutely epic

  • @Jan_Seidel
    @Jan_Seidel 3 роки тому +1

    *Perfect* lesson :)
    Three thumbs up

  • @robertron5303
    @robertron5303 3 роки тому

    Really appreciate your vids man! 👍 even tough I stopped coding a couple of years ago you engage me to catch back up and attend my first upcoming ctf events. Cheers

  • @Topherelius
    @Topherelius 4 роки тому +1

    That was amazing and super informative. Thanks John!

  • @goblinsflying
    @goblinsflying 3 роки тому

    Really great content, learned so much cool stuff and enjoyed it. Thank you and keep videos like these coming....

  • @johnsnow1062
    @johnsnow1062 4 роки тому

    Thank you so much. Was so lovely and helpful. Please continue.

  • @zelalemabate3804
    @zelalemabate3804 2 роки тому

    Awesome walkthrough, thank you!

  • @lIlIllll1
    @lIlIllll1 4 роки тому +1

    Perfect vid for what I needed! Im going through the eCPPT course rn :))

  • @ketononeill8898
    @ketononeill8898 4 роки тому

    Awesome video. You made this pretty easy to understand! Thank you

  • @HK-sw3vi
    @HK-sw3vi 3 роки тому

    this is a banger! I'm new and it made perfect sense

  • @martinndzelen88
    @martinndzelen88 3 роки тому

    i appreciate did learn a lot . You're fast in scripting for a beginner to catch up

  • @ivanlopez8377
    @ivanlopez8377 3 роки тому

    Man, thanks for putting this together.

  • @razzawazza
    @razzawazza 4 роки тому

    That's so cool man. I love your channel thanks for the videos.

  • @Hey-qo2zl
    @Hey-qo2zl 2 роки тому

    Great to have awesome persons like you to help people to learn and much appreciate that you share your valuable knowledge. I am studying OSCP and planning to attend the exam and get the certificate and for sure I will follow your great videos to learn and learn but what make me confused like what is the best to practice for exam HTB or the offensive lab or any other resources and what is the best to study materials first then start practice over and over or study and practice in same time ?!
    We are very lucky to have a person like you to learn from.May god bless you and much appreciate

  • @somekindofbluestuff
    @somekindofbluestuff 3 роки тому

    such a great video! thank you john!!!!

  • @abdallahchbaro836
    @abdallahchbaro836 4 роки тому

    Thank you so much. Spike section was a bit complicated. And you don't need to generate all the characters, you can find them on github

  • @namankumar5464
    @namankumar5464 4 роки тому +1

    Thank so much for this...i have learn a lot ,sir i am waiting for your complete cyber security courses from buggier to master level

  • @matthieuevin3585
    @matthieuevin3585 2 місяці тому

    Comments don’t lie. Great video.

  • @liliwantsvideos
    @liliwantsvideos 3 роки тому

    Thanks a lot!
    This is an amazing insight - i allways wondered how an overflow leads to execution :-p

  • @alcaeo
    @alcaeo 2 роки тому

    Awesome stuff, John!
    Real simple to understand. I am gonna experiment with this and implement something like this into my final school project :)

  • @savoyblue777
    @savoyblue777 3 роки тому

    John you are so good amazing and addicting to watch Thank you

    • @pdemosllegaralos520subs2
      @pdemosllegaralos520subs2 3 роки тому

      Thank you John for the great video. Super Informative! The "beginner" approach is much appreciated.

  • @frosecold
    @frosecold 3 роки тому +6

    1:00:33 I literally said WOOOW, so cool!

  • @heyAyaan7
    @heyAyaan7 4 роки тому

    Great video. Would be awesome if we get videos for the other vulnerable commands of Vulnserver too.

  • @mariorodriguez474
    @mariorodriguez474 3 роки тому

    what a great trip! great job!

  • @000t9
    @000t9 4 роки тому

    I am totally noob in binary exploitation and thank you again !!!

  • @nikolas8741
    @nikolas8741 3 роки тому

    I got a meterpreter!😃 thanks soooo much!

  • @FreezeLuiz
    @FreezeLuiz 4 роки тому +7

    Great vid, John. Can you make a video on a more challenging scenario; where you have IP overwrite however the buffer size is very small to fit the shellcode?

  • @inkotanyi.9185
    @inkotanyi.9185 2 роки тому

    I salute you, Sir!🙌

  • @varadvithalkj1716
    @varadvithalkj1716 4 роки тому

    this was beautiful ,learnt a lot!

  • @metacom_lab
    @metacom_lab 4 роки тому

    I love exploit development. Very well explained.👍

  • @davidrichardsonYT
    @davidrichardsonYT 3 роки тому

    Absolutely fkin amazing.. clever guy. You're now my main UA-cam sub

  • @sardorruziyev6919
    @sardorruziyev6919 3 роки тому

    great video, and i follow step by step. it worked to the last minute... but it is still waiting meter/preter

  • @jerryjohn2655
    @jerryjohn2655 3 роки тому

    Thank you so much John

  • @4ag2
    @4ag2 4 роки тому

    Nice one John 💯

  • @mart.3318
    @mart.3318 3 роки тому

    Great video! Thank you very much!

  • @vaskomarinov7042
    @vaskomarinov7042 3 роки тому

    !GOLDEN CONTENT!

  • @antdgar
    @antdgar 3 роки тому

    Great explanation

  • @merajrabbani
    @merajrabbani 3 роки тому

    Brand New stuff for me well explained. Got overall concept of BOF.

    • @pdemosllegaralos520subs2
      @pdemosllegaralos520subs2 3 роки тому

      Thanks a lot!
      This is an amazing insight - i allways wondered how an overflow leads to execution :-p

  • @parthghughriwala6799
    @parthghughriwala6799 3 роки тому

    God level tutor!

  • @texastitan6567
    @texastitan6567 Рік тому +1

    I’m not great with pentesting but anything I’ve encountered in the cybersec field this far I’ve been able understand with enough studying. Buffer overflow is the exception, I can wrap my head around the theory, I can even follow along your with steps and “understand” but I could never do this exploit on my own. This is at least my 4th time coming back to BOFs to hopefully understand and I just can’t get it.

    • @texastitan6567
      @texastitan6567 Рік тому +1

      And I want to clarify that this is an excellent video I’ve watched multiple times all the way through. Blame is not on the instructor but on the student, it’s just a bit over my head.

  • @h4z4rd1000
    @h4z4rd1000 3 роки тому +1

    It may be my limited understanding of python but if your total_lenght is 2984 and you start your actual exploit code at an offset of 2003 wouldn't that leave you with only 981 bytes for the shellcode? Meaning the in b"C"*(total_lenght - ...) the equation should result in a negative number. Apparently Python dosn't fail if you try this, but that also means your final payload was even longer than 2985 bytes or did I miss something?

  • @frollard
    @frollard 4 роки тому

    I'm reminded of MC Frontalot - Zero Day, nerdcore song about hacking and exploits - always kinda made sense but this video gave a real example. (also recommend frontalot to all the nerds in this chat).
    "Found this bug on my own, no need for a fuzzer.
    'It’s already too late' spreading as we planned.
    No need for the NO OPs, I know just where to land.
    Clearing out the registers, with pointers to my functions,
    loaded to your memory and writing new instructions.
    Braindump i/o, siphoned out the eye holes;
    enticed so i’m digging through the disassembled byte code.
    Push pop change order stack frame FILO
    filesystem inodes, all fall to my flow.
    Running over, there again i go:
    self-propagation engine, polymorphic sideshow.
    Every network, we’re found to get around...
    the exploit payload encoded in this sound.

  • @nuridincersaygili
    @nuridincersaygili 3 роки тому

    This is pure gold..

  • @TheProgrenato
    @TheProgrenato 4 роки тому +1

    You're the best!

  • @karimwassef9892
    @karimwassef9892 4 роки тому

    Love your vids btw!

  • @ChristopherLawson-t4y
    @ChristopherLawson-t4y 2 роки тому

    Amazing video. Thank you