Professional Exploit Development Training

Corelan “ADVANCED”

The Corelan “ADVANCED” exploit development class is a fast-paced, mind-bending, hands-on course where you will learn advanced exploit development techniques from an experienced exploit developer. During this (typically 3 ‘long’ day) course, students will get the opportunity to learn how to write exploits that bypass modern memory protections for the Win32 platform, using Windows 7 as the example platform, but using techniques that can be applied to other operating systems.  The trainer will share his “notes from the field” and various tips & tricks to become more effective at writing exploits.

This is most certainly not an entry level course. In fact, this is a one of the finest and most advanced courses you will find on Win32 exploit development.    

This hardcore, practical, hands-on course will provide students with solid understanding of x86 Windows heap exploitation.  We make sure the course material is kept updated with current evolutions, includes previously undocumented tricks and techniques, and details about research we performed ourselves, so you can apply the research techniques on other applications and operating system versions.  Combined with the way the course is built up, this will turn this class into a truly unique learning experience.

During all of our courses, we don’t just focus on techniques and mechanics, but we also want to make sure you understand why a given technique is used, why something works and why something doesn’t work.  In the advanced course, we also provide you with insights on how to do your own research related with heap exploitation.

We believe those are just a few arguments that makes this training stand out between other exploit development training offerings.   Feel free to check our testimonials page if you want to see real, voluntary, unmodified and uncensored reactions by some of our students.

Finally, we offer you post-training support as well.   If you have taken the course and you still have questions afterwards, we will help.

WARNING: We do not provide solutions for any of the exercises in this course, but we will help you to find the solutions yourself, either during the course of after the course (via the student-only forum)  


Why take this course ?

  • Are you familiar with the basics of exploit development ?  Do you know how to write exploits for saved return pointer overwrites and abuse SEH records with your eyes closed ?  Are you interested inunderstanding how heap spraying works, and why it works ?  Is heap exploitation still a black box for you? Are you now ready for the next step ?   
  • Have you taken the Bootcamp or other commercial courses on exploit development and want to move to the next phase ?
  • Do you want to learn modern techniques to exploit applications on Windows 7 ?
  • Do you want to learn the fine art of writing browser exploits ?
  • Are you able to write ROP chains blindfolded ?  (It is fundamentally important that you have practical experience with constructing/writing your own ROP chain!)
  • Are you willing to suffer and bleed, absorb new knowledge fast and not intimidated by debuggers and assembly instructions…
  • …then this course is exactly what you need !

Still in doubt?  Click here to help find the right course for you.

Target audience

Pentesters, auditors, network/system administrators, reverse engineers, malware analysts, developers, members of a security department, security enthusiasts, or anyone that has a solid and practical basic knowledge of exploit development for Windows already.

If you have a strong desire to learn and willing to suffer & bleed, then check out the schedules & register for one of the classes.  If you are interested in organizing the course at a conference or as a private course at your company, send me an e-mail (peter[dot]ve{at}corelan[dot]be)

Course contents

ASLR & DEP Refresher

  • Bypassing ASLR
  • Bypassing DEP

Heap Spraying

  • Heap Feng Shui & heaplib
  • Precise Heap Spraying in modern browsers

Heap Exploitation (Internet Explorer as an example)

  • DOM Fundamentals
  • Heap Fundamentals
  • Exploiting Browser Use-After-Free conditions
  • Memory leaks / Information Disclosure
  • Heap Overflows, Heap Manipulations and primitives

During the course, students will get the opportunity to work on real vulnerabilities in real applications, use a wide range of heap exploitation techniques  and most importantly learn how to do your own research to find exploitation primitives in complex applications and new versions of Windows.

Warning – The course has a steep learning curve and will require full attention and focus.

The “Course Contents” on this page is subject to change without prior notice & can be updated between the moment of registration and the actual course.  We will try to cover as much as we can from the “Course Contents”, based on the overall ability to absorb knowledge and time needed to complete the exercises, but Corelan GCV cannot ever guarantee that we will be able to cover everything.

Knowledge & Attitude Prerequisites

Students must:

  • be able to read simple C code and simple scripts
  • truly master all basic concepts of exploit development, as listed in our “BOOTCAMP” course.  If you have taken the Bootcamp course and done a lot of practice after taking the class, then you’re probably ready for this class. 
  • be familiar with ROP (i.e. understand how it works on Windows, know how to build a ROP chain, know how to use to generate a chain and how to fix the chain if it doesn’t work)
  • be familiar with reading/writing python/ruby/html/javascript scripts
  • be familiar with using debuggers (we’ll use WinDBG for most part of the course, but we’ll spend some time explaining the basics of using WinDBG.  It is assumed that you have practical experience with Immunity Debugger and
  • be ready to dive into a debugger and read asm for hours and hours and hours
  • be ready to think out of the box and have a strong desire to learn
  • be fluent with managing Windows / Linux operating system and with using vmware workstation/virtualbox
  • be familiar with using Metasploit to generate shellcode
  • have basic practical knowledge of assembly

It’s imperative for students to comply with these prerequisites.

Technical Prerequisites

Unless specified otherwise, students are required to bring the following :

  • A laptop (no netbook) with vmware workstation/virtualbox and enough processing power and RAM (we recommend 4Gb of RAM) to run up to 2 virtual machines at the same time.  The use of a 64bit processor and a 64bit operating system on the laptop will make the exercises more realistic.
  • 2 Virtual machines (Windows 7 SP1 (no patches), Kali Linux (fully up-to-date))

Note : you will receive the exact installation instructions after registration, about a week before class begins, so don’t start installling the VMs yet.

All required tools and applications will be provided during the training or will be downloaded from the internet during the training. 

You must have full administrator access to all machines. You must be able to install and remove software, and you must be able to disable and/or remove firewall/antivirus/… when necessary.

Legal Prerequisites

It will be required to sign a confidentiality agreement at the start of the course.  You will not be admitted to the course without signing this document.  You can find a copy of the document here.