The Vulnerability Scanner is a Python-based tool that scans directories for potential security vulnerabilities based on the OWASP Top 10 vulnerabilities. It uses regular expressions to identify patterns associated with various types of vulnerabilities and reports the findings to the user.
- Scans directories recursively for files containing potential vulnerabilities
- Supports the following OWASP Top 10 vulnerability types:
- Injection
- Broken Authentication
- Sensitive Data Exposure
- XML External Entities (XXE)
- Broken Access Control
- Security Misconfiguration
- Cross-Site Scripting (XSS)
- Insecure Deserialization
- Using Components with Known Vulnerabilities
- Insufficient Logging and Monitoring
- Unvalidated Redirects and Forwards
- Cross-Site Request Forgery (CSRF)
- Server-Side Request Forgery (SSRF)
- Cross-Site Script Inclusion (XSSI)
- Mass Assignment
- Provides a graphical user interface (GUI) for easy interaction
- Allows the user to select the directory to scan
- Displays the scan results in the GUI
- Saves the scan results to a text file for further analysis
-
Clone the repository or download the source code file.
-
Run the script using Python:
python vulnerability_scanner.py
-
In the GUI window, click the "Browse" button to select the directory you want to scan.
-
Click the "Scan Directory" button to start the vulnerability scan.
-
The scan results will be displayed in the text area of the GUI.
-
To save the scan results to a file, click the "Save to File" button and choose a location to save the file.
The vulnerability scanner works by scanning the files in the selected directory recursively. For each file, it reads the content and searches for patterns that match the OWASP Top 10 vulnerability types. The patterns are defined in the Full_Vuln_List
dictionary at the beginning of the script.
The scan_directory()
function is responsible for the actual scanning process. It iterates through the files in the directory, reads their contents, and checks for matches against the vulnerability patterns. When a match is found, the function records the file path, the vulnerability type, and the matching pattern.
The scan_directory_gui()
function is the entry point for the GUI-based usage. It calls the scan_directory()
function and displays the results in the GUI text area. It also provides the functionality to save the scan results to a file.
The GUI is created using the tkinter
library, which provides a standard set of widgets for building desktop applications.
The Vulnerability Scanner requires the following Python libraries:
os
re
tkinter
These libraries are part of the standard Python distribution and should be available without any additional installations.
Contributions to the Vulnerability Scanner project are welcome. If you find any issues or have suggestions for improvements, please feel free to open an issue or submit a pull request on the project's GitHub repository.