html restrictions lesson
This commit is contained in:
committed by
Nanne Baars
parent
007cdaa0d8
commit
01421ca822
91
webgoat-lessons/html-tampering/src/main/resources/html/HtmlTampering.html
Executable file
91
webgoat-lessons/html-tampering/src/main/resources/html/HtmlTampering.html
Executable file
@ -0,0 +1,91 @@
|
||||
<!DOCTYPE html>
|
||||
|
||||
<html xmlns:th="http://www.thymeleaf.org">
|
||||
|
||||
<div class="lesson-page-wrapper">
|
||||
<!-- reuse this lesson-page-wrapper block for each 'page' of content in your lesson -->
|
||||
<!-- include content here. Content will be presented via asciidocs files,
|
||||
which you put in src/main/resources/plugin/lessonplans/{lang}/{fileName}.adoc -->
|
||||
<div class="adoc-content" th:replace="doc:HtmlTampering_Intro.adoc"></div>
|
||||
</div>
|
||||
|
||||
<div class="lesson-page-wrapper">
|
||||
<!-- stripped down without extra comments -->
|
||||
<div class="adoc-content" th:replace="doc:HtmlTampering_Task.adoc"></div>
|
||||
<div class="attack-container">
|
||||
<div class="assignment-success"><i class="fa fa-2 fa-check hidden" aria-hidden="true"></i></div>
|
||||
<form class="attack-form" accept-charset="UNKNOWN" name="task"
|
||||
method="POST"
|
||||
action="/WebGoat/HtmlTampering/task"
|
||||
enctype="application/json;charset=UTF-8">
|
||||
<script>
|
||||
let regex=/^2999.99$/
|
||||
let price = 2999.99
|
||||
document.getElementById("total").innerHTML = '$' + price.toString()
|
||||
document.task.Total.value = price * document.task.QTY.value
|
||||
|
||||
$('#task').submit(function() {
|
||||
if (!regex.test(price.toString())) {
|
||||
alert('Data tampering is disallowed')
|
||||
price = 2999.99
|
||||
return false
|
||||
}
|
||||
else {
|
||||
return true
|
||||
}
|
||||
})
|
||||
|
||||
function update() {
|
||||
let total = price * document.task.QTY.value
|
||||
document.getElementById("total").innerHTML = total.toString()
|
||||
document.task.Total.value = total
|
||||
}
|
||||
</script>
|
||||
<center>
|
||||
<h1>Shopping Cart </h1>
|
||||
</center>
|
||||
<br />
|
||||
<table align="center" cellspacing="0" width="90%" border="1" cellpadding="2">
|
||||
<tbody>
|
||||
<tr>
|
||||
<th width="80%">Shopping Cart Items To Buy Now</th>
|
||||
<th width="10%">Price</th>
|
||||
<th width="3%">Quantity</th>
|
||||
<th width="7%">Total</th>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>56 inch HDTV (model KTV-551)</td>
|
||||
<td align="right">2999.99</td>
|
||||
<td align="right">
|
||||
<input size="6" value="1" name="QTY" type="TEXT" id="QTY"/>
|
||||
</td>
|
||||
<td id="total"></td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<br />
|
||||
<table align="center" cellspacing="0" width="90%" border="0" cellpadding="2">
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>The total charged to your credit card:</td>
|
||||
<td>$2999,99</td>
|
||||
<td>
|
||||
<input name="UPDATE" type="button" value="UpdateCart" onclick="update()"/>
|
||||
</td>
|
||||
<td>
|
||||
<input value="Purchase" name="SUBMIT" type="submit" />
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<input name="Total" type="HIDDEN" value="2999.99" />
|
||||
<br />
|
||||
|
||||
|
||||
</form>
|
||||
<br></br>
|
||||
<div class="attack-feedback"></div>
|
||||
<div class="attack-output"></div>
|
||||
</div>
|
||||
</div>
|
||||
</html>
|
@ -0,0 +1,5 @@
|
||||
html-tampering.title=HTML tampering
|
||||
|
||||
|
||||
html-tampering.tamper.success=Well done, you just bought a TV at a discount
|
||||
html-tampering.tamper.failure=This is too expensive... You need to buy at a cheaper cost!
|
@ -0,0 +1,7 @@
|
||||
|
||||
== Concept
|
||||
Browsers generally offer many options of editing the displayed content. Developers
|
||||
therefore must be aware that the values sent by the user may have been tampered with.
|
||||
== Goals
|
||||
* The user should have a basic understanding of HTML
|
||||
* The user will be able to exploit editing front end of website
|
@ -0,0 +1,2 @@
|
||||
=== Try it yourself
|
||||
This is an internet store. Try to buy TV-s for a lower price.
|
Reference in New Issue
Block a user