Skip to content

Practice fixing OWASP Top 10 vulnerabilities with this vulnerable banking application

License

Notifications You must be signed in to change notification settings

itsecurityco/OWASP-101

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OWASP 101 - Bank App

Table of Contents

IDOR

Insecure Direct Object References (IDOR) is an access control vulnerability that allows an attacker to manipulate another user's account through a unique identifier.

❓ What is a unique identifier?

A unique identifier is a piece of data that is associated with a user and can be:

  • An incremental numeric value.
  • The national identity card (NID) number.
  • The email address.
  • The telephone number.
  • Bank account number, etc.

🔎 How to detect it?

Let's take a look at an example of a real-life exploitation in a banking application.

"IDOR Comic S1" "IDOR Comic S2"

🩹 How to fix it?

Verify that the identifier you are accessing belongs to the user who is logged into the application.

Code Example

PHP

// Check that origin account belongs to the current user.
if ($tef->origin != Auth::user()->product->id) {
    return [
        'code' => '0001',
        'message' => 'Possible bank fraud. Your IP address has been logged.',
    ];
}

Python

# Check that origin account belongs to the current user.
if data["origin"] != request.user.products.get().number:
    return JsonResponse({
        "code": "0001",
        "message": "You don't have permission to perform this operation.",
    })

🚀 Hands-on

Let's try to hack it 💀

  1. Download the distribution code from https://github.com/itsecurityco/OWASP-101/archive/refs/heads/A01.zip and unzip it.
  2. Run docker compose up db -d and and wait until it's over to build and populate the database.
  3. Run docker compose up python -d to build and start the vulnerable Python application.
  4. Run docker compose up php -d to build and start the vulnerable PHP application.

Bank PY

Open your browser and go to http://localhost:5000/ to start hacking the Bank PY.

"Bank PY"

Bank PHP

Open your browser and go to http://localhost:8000/ to start hacking the Bank PHP.

"Bank PHP"


Developed by @itsecurityco

About

Practice fixing OWASP Top 10 vulnerabilities with this vulnerable banking application

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published