BYPASSING CLIENT SIDE JAVASCRIPT VALIDATION
- Layout for this exercise:
data:image/s3,"s3://crabby-images/6d774/6d7748bbc21d331689dd58a19cdb9f085810ae71" alt=""
- Working with OWASP WebGoat v5.4:
data:image/s3,"s3://crabby-images/6c684/6c68491915db68bcf6928e10647bf81846c26f4b" alt=""
1 - Client Side JavaScript Validation
- JavaScript can be used to validate any type of alphanumeric input.
- For instance, this script (invoked by the HTML code with the onclick event) would validate if the numeric input is lower or greater than 10:
data:image/s3,"s3://crabby-images/24c4f/24c4f3a9f22a97fb06aa4d659d7327c5fd727d87" alt=""
data:image/s3,"s3://crabby-images/c9b07/c9b07ca186e737290535d8bfa428a8a826e511bd" alt=""
data:image/s3,"s3://crabby-images/6cedd/6ceddd2bfb58455527138cdb9c1c0b9d68ab4e6b" alt=""
data:image/s3,"s3://crabby-images/d810e/d810e676301eff32335cc4eacd3dbdff1ce65545" alt=""
2 - Bypassing Client Side JavaScript Validation
- In this scenario we have 7 input fields with different validators:
data:image/s3,"s3://crabby-images/4133f/4133f867c56977e700af6d5848bd7fcdfb9d372b" alt=""
- The challenge consists of bypassing each one of the validators.
- Right clicking Inspect Element over Submit:
data:image/s3,"s3://crabby-images/a4900/a4900bd03ad918eb35c312f04ef9feb94e8de8ba" alt=""
- Disabling the input validation:
data:image/s3,"s3://crabby-images/2d307/2d3077217c2f14d248b5620d20ed2e0264f4d4d2" alt=""
data:image/s3,"s3://crabby-images/8f164/8f1649456fa4387e06e0e59c94c863b4eb58e8d3" alt=""
- Now, all the input validators are disabled:
- Field1:
data:image/s3,"s3://crabby-images/2751e/2751ed680697ddc694a289c0da25b8a4323c2e0a" alt=""
data:image/s3,"s3://crabby-images/aece3/aece3ce9cc932cccaa83f86e28d2336a33b6ea7c" alt=""
- Field2:
data:image/s3,"s3://crabby-images/755b5/755b56a863d6bfe46844a7b6b681d24f61fddb40" alt=""
data:image/s3,"s3://crabby-images/fa8ac/fa8ace5c8d9711970f5203a918fb9d225379c4a1" alt=""
- Field3:
data:image/s3,"s3://crabby-images/d0b41/d0b41e5d0e4b7b58f3ca4b53325135384abc805e" alt=""
data:image/s3,"s3://crabby-images/b5f27/b5f27ee2bddd8e399c145dd8224340ca50f81ccd" alt=""
- Field4:
data:image/s3,"s3://crabby-images/fe8fa/fe8fadf1fb48c47b67806de5ec4ab7f565b9d728" alt=""
data:image/s3,"s3://crabby-images/190c5/190c58e89cd2f4ec85bfbfb3c3ac1db6684f9140" alt=""
- Field5:
data:image/s3,"s3://crabby-images/cd981/cd981f0e1a214dca4de1232b14d8f7efdb4723a8" alt=""
data:image/s3,"s3://crabby-images/cf5f5/cf5f55bfffddfb39b6f6350f427311100d51c4cb" alt=""
- Field6:
data:image/s3,"s3://crabby-images/5bc66/5bc664ce0838f1a1e84e060ae02bd971791c4ec2" alt=""
data:image/s3,"s3://crabby-images/53a42/53a42abdc4655334ae1a16065778756fbd308a0d" alt=""
- Field7:
data:image/s3,"s3://crabby-images/0b367/0b3679c466906ec9a10124508d1bc9e8edef6007" alt=""
data:image/s3,"s3://crabby-images/e6d52/e6d52e1a3d6f781678a611bdf3ca3b7a24ce1b4a" alt=""
- Once submitting the inputs the server is not able to correctly validate them and the attack is successful:
data:image/s3,"s3://crabby-images/33afe/33afe255a3fe20fad6ad21d0d2074f51feabd05a" alt=""
data:image/s3,"s3://crabby-images/b9c71/b9c71810175f47ab34cbb6d95b3e9d4626aa1da6" alt=""