Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/integeralex/sql-injection-demo
This project is a demonstration of a SQL injection vulnerability in a Node.js application using Express.js and PostgreSQL. It showcases how an attacker can exploit such vulnerabilities to execute arbitrary SQL queries and potentially gain unauthorized access to sensitive data in the database.
https://github.com/integeralex/sql-injection-demo
demo docker nodejs postgresql sqlinject sqlinjection
Last synced: 26 days ago
JSON representation
This project is a demonstration of a SQL injection vulnerability in a Node.js application using Express.js and PostgreSQL. It showcases how an attacker can exploit such vulnerabilities to execute arbitrary SQL queries and potentially gain unauthorized access to sensitive data in the database.
- Host: GitHub
- URL: https://github.com/integeralex/sql-injection-demo
- Owner: IntegerAlex
- Created: 2024-05-02T17:47:06.000Z (8 months ago)
- Default Branch: master
- Last Pushed: 2024-05-02T18:07:26.000Z (8 months ago)
- Last Synced: 2024-12-02T09:03:05.640Z (about 1 month ago)
- Topics: demo, docker, nodejs, postgresql, sqlinject, sqlinjection
- Language: JavaScript
- Homepage:
- Size: 21.5 KB
- Stars: 1
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# SQL Injection Demo with Express.js and PostgreSQL
This repository contains a simple Node.js application built with Express.js that demonstrates how SQL injection vulnerabilities can be exploited when interacting with a PostgreSQL database.
## Prerequisites
Before running the application, ensure that you have the following installed:
- Node.js and npm
- Docker (for running PostgreSQL in a container)## Setting Up the Application
### Clone this repository to your local machine
`git clone https://github.com/IntegerAlex/sql-injection-demo`
Navigate to the project directory:
`cd project_directory`
Install dependencies:`npm install`
## PostgreSQL Docker Container
To run the application, you'll need a PostgreSQL database. You can use Docker to quickly spin up a PostgreSQL container:
`docker run --name my-postgres -e POSTGRES_PASSWORD=mysecretpassword -p 5432:5432 -d postgres`
### Running the Application
Once the PostgreSQL container is running, you can start the Node.js application:
TO initilize database run the following command:
`npm run db`To start the application, run:
`npm run dev`The application will start listening on port 3000 by default.
## SQL Injection Demo
The application includes a vulnerable endpoint (/products) that is susceptible to SQL injection. You can perform a SQL injection attack by sending a POST request with malicious input.
Here's an example of a SQL injection payload to retrieve all products from the database:
```sql
' UNION SELECT ProductID, ProductName, Description, Price, StockQuantity FROM Products; --
```You can use tools like curl, Postman, or any HTTP client to send the malicious request to the /products endpoint and observe the results.
Disclaimer
This application is for educational purposes only. SQL injection vulnerabilities can have severe consequences if exploited in a real-world application. Always sanitize and validate user input, use parameterized queries, and implement proper access controls to prevent SQL injection attacks in production environments.