Skip to content

navyugj/WebGoat

Repository files navigation

WebGoat: A deliberately insecure Web Application

Build Status OWASP Slack

Important Information

This is a work in progress of the WebGoat Lesson Server, which is currently UNDER MAJOR DEVELOMENT

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.

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/)

Easy Run Instructions ( For non-developers )

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)

  1. Download the executable jar file which contains all the lessons:

https://s3.amazonaws.com/webgoat-war/webgoat-container-7.0-SNAPSHOT-war-exec.jar

  1. Run it using java:
$ java -jar webgoat-container-7.0-SNAPSHOT-war-exec.jar
  1. Then navigate in your browser to: (http://localhost:8080/WebGoat)

  2. If you would like to change the port or other options, use:

$ java -jar webgoat-container-7.0-SNAPSHOT-war-exec.jar --help

For Developers

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):

  1. 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.

  1. 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

  1. 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/

Packages

No packages published

Languages

  • JavaScript 47.6%
  • Java 35.9%
  • HTML 13.6%
  • CSS 2.6%
  • Shell 0.1%
  • Ruby 0.1%
  • Other 0.1%