Skip to content

i-am-shipwrecked/java-sql-injector

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

57 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SQL Injector - Pentesting Toolkit

Welcome to SQL Injector, your comprehensive penetration testing toolkit designed to assess and fortify the security of your backend databases. SQL injection, a prevalent attack vector, allows you to detect and remedy vulnerabilities in your application's database layer.

SQL injection, also known as SQLI, is a common attack vector that uses malicious SQL code for backend database manipulation to access information that was not intended to be displayed. This information may include any number of items, including sensitive company data, user lists or private customer details.


To start application

mvn spring-boot:run

To run tests

mvn test

SQL-injection-needle


Run Database Locally

To run the database locally, follow these steps:

  1. Open a terminal or Git Bash in the project's root folder.

  2. Build the Docker image:

    docker-compose build
  3. Start the Docker container in the background:

    docker-compose up -d
  4. Launch the Docker container:

    docker start postgres
  5. Check the container status:

    docker container ls -a

Ensure that the database is successfully started and ready for use.


API Endpoints:


You can access detailed documentation using Swagger following this link: http://localhost:8080/swagger-ui/index.html

POST http://localhost:8080/runTests/level1

Request body:

  {
    "url": "https://www.example.com/"
  }

Response body:

{
  Sql injection with EASY load is - DONE
}

Response status:

200
  • Running tests with 10 SQL injections.

POST http://localhost:8080/runTests/level2

Request body:

  {
    "url": "https://www.example.com/"
  }

Response body:

{
  Sql injection with MID load is - DONE
}

Response status:

200
  • Running tests with 20 SQL injections.

POST http://localhost:8080/runTests/level3

Request body:

  {
    "url": "https://www.example.com/"
  }

Response body:

{
  Sql injection with HARD load is - DONE
}

Response status:

200
  • Running tests with 30 SQL injections.

Automated Testing Framework with Selenium

This project is designed to offer a robust Automated Testing Framework (ATF) that seamlessly integrates Cucumber and Serenity, providing an efficient and readable solution for automated tests. It facilitates the incorporation of behavior-driven development (BDD) practices into your testing process.

Key Features

  1. Cucumber Integration: Leverage Cucumber for expressive BDD-style scenarios in plain text.

  2. Serenity Reporting: Utilize detailed and user-friendly Serenity HTML reports for clear test result visualization.

  3. Flexible Configuration: Easily configure test runs with dynamic properties and links in the sql_injector.properties file.

  4. Runners: Significance of Three Runners: In this project, we utilize three distinct runners - one for Serenity, one for Spring, and another for Cucumber - to cater to various testing needs.

Getting Started

Clone Repository

git clone https://github.com/your/repository.git

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published