Headless Burp provides an extension to Burp that allows you to run Burp Suite’s Spider and Scanner tools in headless mode via command-line.
However, it can do more! It can produce a JUnit like report which in turn could instruct the CI server to mark the build as “failed” whenever any vulnerabilities are found. You can also mark some issues as false positives and those will not be reported anymore on the next scan reports.
./mvnw
The extension is packaged as a fat jar at target/headless-burp-scanner-master-SNAPSHOT-jar-with-dependencies.jar
Also ReadPeda – Python Exploit Development Assistance for GDB
Bu8ld the extension as shown above or install it from the BApp Store
On *nix:
java -Xmx1G -Djava.awt.headless=true \
-classpath headless-burp-scanner-master-SNAPSHOT-jar-with-dependencies.jar:burpsuite_pro_v1.7.31.jar burp.StartBurp \
--unpause-spider-and-scanner \
--project-file=project.burp -c config.xml
On Cygwin:
java -Xmx1G -Djava.awt.headless=true \
-classpath "headless-burp-scanner-master-SNAPSHOT-jar-with-dependencies.jar;burpsuite_pro_v1.7.31.jar" burp.StartBurp \
--unpause-spider-and-scanner \
--project-file=project.burp -c config.xml
java -Xmx1G -Djava.awt.headless=true \
-classpath burpsuite_pro_v1.7.31.jar burp.StartBurp \
--unpause-spider-and-scanner \
--project-file=project.burp -c config.xml
On Cygwin:
java -Xmx1G -Djava.awt.headless=true \
-classpath "burpsuite_pro_v1.7.31.jar" burp.StartBurp \
--unpause-spider-and-scanner \
--project-file=project.burp -c config.xml
<?xml version="1.0" encoding="UTF-8"?>
<config xmlns="http://nets.eu/burp/config">
<reportType>HTML</reportType> <!-- JUNIT|HTML|XML -->
<targetSitemap><![CDATA[http://localhost:5432]]></targetSitemap> <!-- atleast one of targetSitemap or scope must be specified -->
<scope> <!-- atleast one of targetSitemap or scope must be specified -->
<url><![CDATA[http://localhost:5432/]]></url> <!-- multiple allowed -->
<exclusions> <!-- optional -->
<exclusion><![CDATA[localhost:5432/#/logout]]></exclusion>
</exclusions>
</scope>
<false-positives> <!-- optional -->
<issue>
<type>5244416</type>
<path>.*</path>
</issue>
<issue>
<type>5247488</type>
<path>.*bower_components.*</path>
</issue>
</false-positives>
</config>
For an example configuration file, see config.xml and headless-burp-scanner-config.xsd for the xsd
--project-file=VAL Open the specified project file; this will be created as a new project if the file does not exist (mandatory)
-c (--config) <file> Configuration file (mandatory)
-p (--prompt) Indicates whether to prompt the user to confirm the shutdown (useful for debugging)
-v (--verbose) Enable verbose output
--diagnostics Print diagnostic information
--use-defaults Start with default settings
--collaborator-server Run in Collaborator server mode
--collaborator-config=VAL Specify Collaborator server configuration file; defaults to collaborator.config
--config-file=VAL Load the specified project configuration file(s); this option may be repeated to load multiple files
--user-config-file=VAL Load the specified user configuration file(s); this option may be repeated to load multiple files
--auto-repair Automatically repair a corrupted project file specified by the --project-file option
The extension has been designed to be versatile and support several scenarios
<?xml version="1.0" encoding="UTF-8"?>
<config xmlns="http://nets.eu/burp/config">
<reportType>HTML</reportType>
<targetSitemap><![CDATA[http://localhost:5432]]></targetSitemap>
<scope>
<url><![CDATA[http://localhost:5432/auth]]></url>
<url><![CDATA[http://localhost:5432/users]]></url>
<url><![CDATA[http://localhost:5432/users/1]]></url>
<url><![CDATA[http://localhost:5432/users?search=asd]]></url>
<url><![CDATA[http://localhost:5432/bar/foo]]></url>
</scope>
</config>
<?xml version="1.0" encoding="UTF-8"?>
<config xmlns="http://nets.eu/burp/config">
<reportType>HTML</reportType>
<targetSitemap><![CDATA[http://localhost:5432]]></targetSitemap>
<scope>
<url><![CDATA[http://localhost:5432/auth]]></url>
<url><![CDATA[http://localhost:5432/users]]></url>
<url><![CDATA[http://localhost:5432/users/1]]></url>
<url><![CDATA[http://localhost:5432/users?search=asd]]></url>
<url><![CDATA[http://localhost:5432/bar/foo]]></url>
<exclusions>
<exclusion><![CDATA[localhost:5432/#/logout]]></exclusion>
<exclusion><![CDATA[localhost:5432/#/users/delete]]></exclusion>
<exclusion><![CDATA[localhost:5432/#/creepy/crawly]]></exclusion>
</exclusions>
</scope>
</config>
<?xml version="1.0" encoding="UTF-8"?>
<config xmlns="http://nets.eu/burp/config">
<reportType>HTML</reportType>
<targetSitemap><![CDATA[http://localhost:5432]]></targetSitemap>
<scope>
<url><![CDATA[http://localhost:5432/auth]]></url>
<url><![CDATA[http://localhost:5432/users]]></url>
<url><![CDATA[http://localhost:5432/users/1]]></url>
<url><![CDATA[http://localhost:5432/users?search=asd]]></url>
<url><![CDATA[http://localhost:5432/bar/foo]]></url>
<exclusions>
<exclusion><![CDATA[localhost:5432/#/logout]]></exclusion>
<exclusion><![CDATA[localhost:5432/#/users/delete]]></exclusion>
<exclusion><![CDATA[localhost:5432/#/creepy/crawly]]></exclusion>
</exclusions>
<false-positives>
<issue>
<type>5244416</type>
<path>.*</path>
</issue>
<issue>
<type>5247488</type>
<path>.*bower_components.*</path>
</issue>
</false-positives>
</scope>
</config>
Sometimes, just spidering a target scope and and performing on a scope of URLs doesnt give much value. For e.g. when scanning a web application where routing is handled using JavaScript. Burp scans can discover more if it can scan more “real-world” requests and responses. This way, it can attack the target URLs more effectively and potentially discover more than a shot in the dark spider + scan approach.
To handle such cases, it would be best to let the burp proxy intercept some real traffic to the target and build up a sitemap for itself. The Headless Burp Proxy extension provides an simple way to achieve this.
--project-file
option. This is where the “seed” data for scanning is going to be stored.4646
if you use the extension) by setting HTTP_PROXY or similar.<?xml version="1.0" encoding="UTF-8"?>
<config xmlns="http://nets.eu/burp/config">
<reportType>HTML</reportType>
<targetSitemap><![CDATA[http://localhost:5432]]></targetSitemap>
<scope>
<url><![CDATA[http://localhost:5432]]></url>
<exclusions>
<exclusion><![CDATA[localhost:5432/#/logout]]></exclusion>
</exclusions>
<false-positives>
<issue>
<type>5244416</type>
<path>.*</path>
</issue>
</false-positives>
</scope>
</config>
--project-file
optionThe headless burp scanner plugin can do these
Maven plugin that allows you to run Burp Suite’s Proxy and Scanner tools in headless mode.
The plugin is essentially a wrapper around the Headless Burp Proxy and Headless Burp Scanner extensions. It offers easy way to integrate security testing using Burp Suite into the project build lifecycle.
<build>
...
<plugins>
...
<plugin>
<groupId>eu.nets.burp</groupId>
<artifactId>burp-maven-plugin</artifactId>
<version>master-SNAPSHOT</version>
<configuration>
<burpSuite>burp/burpsuite_pro_v1.7.31.jar</burpSuite>
<burpProjectFile>target/headless-burp-project.burp</burpProjectFile>
<burpConfig>burp/config.xml</burpConfig>
<headless>true</headless>
<promptOnExit>false</promptOnExit>
<verbose>true</verbose>
<skip>false</skip>
</configuration>
<executions>
<execution>
<id>start-burp-proxy</id>
<phase>pre-integration-test</phase>
<goals>
<goal>start-proxy</goal>
</goals>
</execution>
<execution>
<id>stop-burp-proxy</id>
<phase>post-integration-test</phase>
<goals>
<goal>stop-proxy</goal>
</goals>
</execution>
<execution>
<id>start-burp-scan</id>
<phase>verify</phase>
<goals>
<goal>start-scan</goal>
</goals>
</execution>
</executions>
</plugin>
...
</plugins>
...
</build>
Provides an extension to Burp that allows you to run, stop and capture results from the Burp proxy tool in headless mode.
4646
)"SHUTDOWN"
) on port (default 4444
).On *nix:
java -Xmx1G -Djava.awt.headless=true \
-classpath headless-burp-proxy-master-SNAPSHOT-jar-with-dependencies.jar:burpsuite_pro_v1.7.31.jar burp.StartBurp \
--project-file=project.burp
On Cygwin:
java -Xmx1G -Djava.awt.headless=true \
-classpath "headless-burp-proxy-master-SNAPSHOT-jar-with-dependencies.jar;burpsuite_pro_v1.7.31.jar" burp.StartBurp \
--project-file=project.burp
--project-file=VAL Open the specified project file; this will be created as a new project if the file does not exist (mandatory)
--proxyPort VAL Proxy port
--shutdownPort VAL Shutdown port
--shutdownKey VAL Shutdown key
-p (--prompt) Indicates whether to prompt the user to confirm the shutdown (useful for debugging)
-v (--verbose) Enable verbose output
--diagnostics Print diagnostic information
--use-defaults Start with default settings
--collaborator-server Run in Collaborator server mode
--collaborator-config=VAL Specify Collaborator server configuration file; defaults to collaborator.config
--config-file=VAL Load the specified project configuration file(s); this option may be repeated to load multiple files
--user-config-file=VAL Load the specified user configuration file(s); this option may be repeated to load multiple files
--auto-repair Automatically repair a corrupted project file specified by the --project-file option
echo SHUTDOWN >> /dev/tcp/127.0.0.1/4444
or
echo SHUTDOWN | netcat 127.0.0.1 4444
or
echo SHUTDOWN | ncat 127.0.0.1 4444
Prompt injection is a type of security vulnerability that can be exploited to control the…
Firefly is an advanced black-box fuzzer and not just a standard asset discovery tool. Firefly…
Winit is a robust, cross-platform library designed for creating and managing windows in Rust applications.…
In today’s digital age, convenience often comes at the cost of security. One such overlooked…
Terminal GPT (tgpt) offers a seamless way to bring the power of ChatGPT 3.5 directly…
garak checks if an LLM can be made to fail in a way we don't…