Home Lab Setup SEED Labs Books Lectures Workshops
SEED Logo

Shellcode Development Lab

Overview

Shellcode is widely used in many attacks that involve code injection. Writing shellcode is quite challenging. Although we can easily find existing shellcode from the Internet, to be able to write our own shellcode from the scratch is always exciting. There are several interesting techniques involved in shellcode. The purpose of this lab is to help students understand these techniques so they can write their own shellcode.

There are two main challenges in writing shellcode: one is to find out the addresses of the data used in the command, and the other is to ensure that there is no zero in the binary code. In this lab, students will see how to address these two challenges. Both amd64 and arm64 achitectures are supported in this lab.

Tasks (PDF)

  • VM version: This lab has been tested on our SEED Ubuntu-20.04 VM
  • Lab setup files: DO NOT unzip the file in a shared folder, as that would cause problems. Copy the zip file to another folder inside the VM, and then use the unzip command to unpack.

Time (Suggested)

  • Supervised (closely-guided lab session): 2 hours
  • Unsupervised (take-home project): 1 week

Older Version

This lab was updated in December 2023. The changes are quite significant (supports for ARM are added). The older version can still be found here:

SEED Videos

SEED Books (English) (Chinese)

For ARM64 Shellcode

The code examples given in this lab description are based on the x86/x64 architectures. If you are using Apple M1/M2 machines, you can follow the instructions in this document: Writing ARM64 Shellcode (in Ubuntu).

Feedback and Help

Please give us your feedback on this lab using this feedback form.
The SEED Labs project is open source. If you are interested in contributing to this project, please check out our Github page: https://github.com/seed-labs/seed-labs.