Burp Suite — Web Security Testing is an integrated platform/graphical tool for performing security testing of web applications. Its various tools work seamlessly together to support the entire testing process, from initial mapping and analysis of an application’s attack surface, through to finding and exploiting security vulnerabilities. Burp Suite is installed by default in Kali Linux.
The tool is written in Java and developed by PortSwigger Web Security.
The tool has three editions:
- Community Edition
- Professional Edition
- Enterprise Edition
Pricing of the Editions :
Sample Reports of Burp Suite Edition:
Web vulnerability scanner:
- Coverage of over 100 generic vulnerabilities, such as SQL injection and cross-site scripting (XSS), with a great performance against all vulnerabilities in the OWASP top 10.
- Burp’s cutting-edge web application crawleraccurately maps content and functionality, automatically handling sessions, state changes, volatile content, and application logins.
- Burp has pioneered the use of highly innovative out-of-band techniques (OAST) to augment the conventional scanning model. The Burp Collaborator technology allows Burp to detect server-side vulnerabilities that are completely invisible in the application’s external behavior, and even to report vulnerabilities that are triggered asynchronously after scanning has completed.
- The Burp Infiltrator technology can be used to perform interactive application security testing (IAST) by instrumenting target applications to give real-time feedback to Burp Scanner when its payloads reach dangerous APIs within the application.
- Burp’s scanning logic is continually updated with enhancements to ensure it can find the latest vulnerabilities and new edge cases of existing vulnerabilities.
- All reported vulnerabilities contain detailed custom advisories. These include a full description of the issue and step-by-step remediation advice.
Scheduled and repeat scans:
- Burp Suite Enterprise Edition can perform scheduled scans at specific times, or carry out one-off scans on demand.
- You can configure repeat scans to run indefinitely or until a defined endpoint.
- You can view in a single place the entire scan history for a given web site.
- Burp Suite Enterprise Edition has extreme scalability and can scan indefinitely many web sites in parallel.
- You can configure all of your organization’s web sites in one place, organized to reflect your organizational structure.
- All scan results are aggregated in one place, providing an at-a-glance view of your organization’s security posture
- The scalable agent pool distributes workload across multiple machines, allowing your deployment to grow to any size, and perform as many parallel scans as your organization requires.
- Burp Suite Enterprise Edition supports multiple users with role-based access control (RBAC) to restrict access to sensitive data. There are no licensing restrictions on the number of users.
- Bring security automation forward in your development lifecycle using Burp’s CI integration.
- Automatically launch vulnerability scans from your CI system via the REST API.
- There are ready-made native CI plugins for popular platforms such as Jenkins and TeamCity, and a generic CI driver that can be easily installed in any CI system.
- You can run scans per commit, on a schedule, or as part of your deployment pipelines.
- CI integration can be configured to break software builds based on the severity of discovered issues.
- The BApp Store is a repository of ready-to-use extensions contributed by the Burp user community. These can be installed with a single click from within the Burp UI.
Download the Software and Install it:
To begin installing Burp Suite visit and select the Get Community option (the third one) to get Burp Suite for free.
Click on the green Download button.
Save the .sh script and give it execution permissions by running:
# chmod +x <package.sh>
In this case for the current version at this date I run:
# chmod +x burpsuite_community_linux_v2020_1.sh
Once the execution rights were given execute the script by running:
A GUI installer will prompt, press on “Next” to continue.
Leave the default installation directory (/opt/BurpSuiteCommunity) unless you need a different location and press Next to continue.
Seek “Create Symlink” selected and leave the default directory and press Next.
The installation process will start. Once the process ends click on Finish.
From your X-Window manager apps menu select Burp Suite, in my case it was located on the category “Other”.
Decide if you wish to share your Burp Suite experience or not, click I Decline, or I Accept to continue.
Leave Temporary Project and press Next.
Leave Use Burp defaults and press Start Burp to launch the program.
You’ll see Burp Suite main screen:
Before proceeding, open Firefox and open http://burp.
A screen like the shown below will show up, on the upper right corner click on CA Certificate.
Download and save the certificate.
On the Firefox menu click on Preferences, then click on Privacy and Security and scroll down until you find the Certificates section, then click on View Certificates as shown below:
Click on Import:
Select the certificate you got previously and press Open:
Click on “Trust this CA to identify websites.” and press OK.
Now, still on the Firefox Preferences menu click on General in the menu located in the left side and scroll down until reaching Network Settings, then click on Settings.
Select Manual Proxy Configuration and in the HTTP Proxy, field set the IP 127.0.0.1, checkmark the “Use this proxy server for all protocols”, then click OK.
Now Burp Suite is ready to show how it can intercept traffic through it when defined as proxy. On Burp Suite click on the Proxy tab and then on the Intercept sub tab making sure intercept is on and visit any website from your Firefox browser.
The request between the browser and the visited website will go through Burp suite, allowing you to modify the packets as in a Man in the Middle attack.
The example above is the classical Proxy feature show for beginners. Yet, you do not always can configure the target’s proxy, if you did, a keylogger would be more helpful than a Man in the Middle attack.
Now we will use DNS and the Invisible Proxy feature to capture traffic from a system we cannot configure the proxy on.
To begin run Arpspoof (on Debian and based Linux systems you can install with through apt install dsniff) Once installed dsniff with arpspoof, to capture packets from the target to the router on the console run:
# sudo arpspoof -i <Interface-Device> -t <Target-IP> <Router-IP>
Then to capture packets from the router to the target run in a second terminal:
# sudo arpspoof -i <Interface-Device> -t <Router-IP> <Target-IP>
To prevent blocking the victim enable IP forwarding:
# echo 1 > /proc/sys/net/ipv4/ip_forward
Redirect all traffic to port 80 and 443 to your device using iptables by running the commands below:
# sudo iptables -t nat -A PREROUTING -p tcp — dport 80 -j DNAT — to-destination
# sudo iptables -t nat -A PREROUTING -p tcp — dport 443 -j DNAT — to-destination
Run BurpSuite as root, otherwise some steps like enabling new proxies on specific ports won’t work:
# java -jar -Xmx4g /opt/BurpSuiteCommunity/burpsuite_community.jar
If the following warning appears press OK to continue.
Once BurpSuite is open, click on Proxy>Options and click on the Add button.
Select 80 and on Specific address select your Local network IP address:
Then click on Request handling tab, checkmark Support Invisible proxying (enable only if needed) and press OK.
Repeat the steps above now with port 443, click on Add.
Set the port 443 and again select your local network IP address.
Click on Request Handling, checkmark support for invisible proxying and press OK.
Mark all proxies as running and as invisible.
Now from the target device visit a website, the Intercept tab will show the capture:
As you can see you managed to capture packets without previous proxy configuration on the target’s browser.
Azure MCT | DevSecOps | Certified SRE | SAFe4 DevOps Practitioner | Azure 4x Certified | DevOps Institute Trainer | ITSM