forked from WebGoat/WebGoat
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request WebGoat#487 from matthias-g/xssFixes
Small lesson improvements
- Loading branch information
Showing
4 changed files
with
9 additions
and
9 deletions.
There are no files selected for viewing
10 changes: 5 additions & 5 deletions
10
...e-scripting/src/main/resources/lessonPlans/en/CrossSiteScripting_content6a.adoc
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,15 +1,15 @@ | ||
== Identify Potential for DOM-Based XSS | ||
|
||
DOM-Based XSS can usually be found by looking for the route configurations in the client-side code. | ||
Look for a route that takes inputs that you can ID being 'reflected' to the page. | ||
Look for a route that takes inputs that are being 'reflected' to the page. | ||
|
||
For this example, you'll want to look for some 'test' code in the route handlers (WebGoat uses backbone as its primary javascript library). | ||
Sometimes, test code gets left in production (and often times test code is very simple and lacks security or any quality controls!). | ||
|
||
Your objective is to find the route and exploit it. First though ... what is the base route? As an example, look at the URL for this lesson ... | ||
it should look something like /WebGoat/start.mvc#lesson/CrossSiteScripting.lesson/9 (although maybe slightly different). The 'base route' in this case is: | ||
it should look something like /WebGoat/start.mvc#lesson/CrossSiteScripting.lesson/9. The 'base route' in this case is: | ||
*start.mvc#lesson/* | ||
The *CrossSiteScripting.lesson/9* after that are parameters that are processed by the javascript route handler. | ||
|
||
The *CrossSiteScripting.lesson/#* after that are parameters that are processed by javascript route handler. | ||
|
||
So, what is test route for this test code? | ||
So, what is the route for the test code that stayed in the app during production? | ||
To answer this question, you have to check the javascript source. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters