Current stable version and instructions can be found at: WebGoat-Legacy
WebGoat is a deliberately insecure web application maintained by OWASP designed to teach web application security lessons.
This program is a demonstration of common server-side application flaws. The exercises are intended to be used by people to learn about application security and penetration testing techniques.
- Home Page
- OWASP Project Home Page
- Source Code
- Easy-Run Download TBD
- Wiki
- FAQ (old info):
- Project Leader - Direct to Bruce Mayhew
- Mailing List - WebGoat Community - For most questions
WARNING 1: While running this program your machine will be extremely vulnerable to attack. You should to disconnect from the Internet while using this program. WebGoat's default configuration binds to localhost to minimize the exposure.
WARNING 2: This program is for educational purposes only. If you attempt these techniques without authorization, you are very likely to get caught. If you are caught engaging in unauthorized hacking, most companies will fire you. Claiming that you were doing security research will not work as that is the first thing that all hackers claim.
You can find more information about WebGoat at: (https://github.com/WebGoat/)
Note - Use WebGoat-Legacy for a stable build
Follow these instructions if you simply wish to run WebGoat
Prerequisites:
Java VM >= 1.6 installed ( JDK 1.7 recommended)
- Download the executable jar file which contains all the lessons:
https://s3.amazonaws.com/webgoat-war/webgoat-container-7.0-SNAPSHOT-war-exec.jar
- Run it using java:
$ java -jar webgoat-container-7.0-SNAPSHOT-war-exec.jar
-
Then navigate in your browser to: (http://localhost:8080/WebGoat)
-
If you would like to change the port or other options, use:
$ java -jar webgoat-container-7.0-SNAPSHOT-war-exec.jar --help
Follow these instructions if you wish to run Webgoat and modify the source code as well.
Prerequisites: /
- Java >= 1.6 ( JDK 1.7 recommended )
- Maven > 2.0.9
- Your favorite IDE, with Maven awareness: Netbeans/IntelliJ/Eclipse with m2e installed.
- Git, or Git support in your IDE
Note: WebGoat source code can be downloaded at: (https://github.com/WebGoat/WebGoat).
Building the project (Developers)
Using a command shell/window:
$ mvn clean package
Before you can run the project you need to build some lessons first clone https://github.com/WebGoat/WebGoat-Lessons and run:
$ cd WebGoat-Lessons
$ mvn package
$ cp target/plugins/*.jar WebGoat/webgoat-container/target/webgoat-container-7.0-SNAPSHOT/plugin_lessons/
Then you can run the project with one of the steps below (From the WebGoat folder not WebGoat-Lessons):
- Maven-Tomcat Plugin using a command shell/window:
$ mvn -pl webgoat-container tomcat7:run-war
Browse to http://localhost:8080/WebGoat
Maven will run the project in an embedded tomcat.
- Java JAR the package phase also builds an executable jar file. You can run it using:
$ cd webgoat-container/target
$ java -jar webgoat-container-7.0-SNAPSHOT-war-exec.jar http://localhost:8080/WebGoat
Browse to http://localhost:8080/WebGoat
- Tomcat the package phase also builds a war file. You can deploy it using:
$ cp webgoat-container/target/webgoat-container-7.0-SNAPSHOT-war-exec.jar <tomcat>/webapps/