burplabs
Burplabs
burplabs is a modular, Python-based CLI tool that automates solving labs from
PortSwigger Web Security Academy
.
Its like like netexec
, but made for web apps.
Github: burplabs
It currently has 113/269 labs and I am adding rest of the labs daily.
I know this not something new but this helped me to get better with Python Scripting and I adjusted many other things. I recommend to try this when you know how lab is solved and just want to solve it. Please do not use this before understanding the concepts.
Features
- CLI interface
- Modular architecture – each lab is a standalone Python file
- Custom Proxy and No Proxy also support (
--proxy
,--no-proxy
) - Docker-compatible
- Easily extensible - add your own code if you want!
Installation
Option 1: Install via pip (recommended)
Windows
python -m venv burplabs-venv
.\burplabs-venv\scripts\Activate.ps1
pip install burplabs
Option 2: Git clone
git clone https://github.com/spbavarva/portswigger-labs-scripts.git
cd portswiggerlab
pip install .
(Docker will be added soon)
Usage
View Help
burplabs -h

List All Available Labs
burplabs --list-labs
Interactive Mode
burplabs --interactive
and then just follow the steps. You can even enter custom proxy when it prompts or if you want to use burp proxy then just open burp and hit ‘Y’ when it prompts for default proxy to get requests on your burp.
Or you can hit ’n’ when it prompts and you don’t need to open burp at all.

Adding New Labs
To add a new lab:
- Create a new file in
burplabs/labs/name-of-the-folder
, e.g.sql_lab3.py
- It must define a
run(url, payload, proxies=None)
function - That’s it! The lab will be auto-detected and usable like:
portswiggerlab sql_lab3 --url ... --payload ...
Author
Credit to Rana Khalil for inspiring me for this!
Built by
Sneh aka mystic_mido
If you like it, give it a ⭐ on
GitHub
!