| Titel | SourceCodester Invoicing System In PHP 1.0 Second-Order SQL Injection |
|---|
| Beschreibung | A Second-Order SQL Injection vulnerability exists in the invoicing generation logic of Invoicing System In PHP version 1.0.
While the primary entry point $_GET['id'] is checked with is_numeric(), the application retrieves data from the orders table and uses those values (which may have been injected previously via other vulnerable forms like orders.php or customers.php) to construct subsequent SQL queries without any sanitization or prepared statements.
Specifically, in IGST_Invoice.php:
$custname=$row["customer_name"]; // Data from DB
if($custname != ''){
$custqry="select * from customers where customer_name='".$custname."'"; // Injection point
$res_cust = mysqli_query($conn, $custqry);
}
$categoryid=$row["category"]; // Data from DB
if($categoryid != ''){
$catqry="select * from category where category_id='".$categoryid."'"; // Injection point
$res_cat = mysqli_query($conn, $catqry);
}
If an attacker manages to store a payload like Admin' OR '1'='1 in the customer_name or category field, they can manipulate the logic of the invoice generation, exfiltrate data from other tables, or perform administrative actions on the database. |
|---|
| Quelle | ⚠️ https://gist.github.com/c4ttr4ck/f60dfb9fc65a98ad6dde1840dc2c1a5e |
|---|
| Benutzer | c4ttr4ck (UID 75518) |
|---|
| Einreichung | 26.04.2026 23:12 (vor 1 Monat) |
|---|
| Moderieren | 24.05.2026 08:35 (27 days later) |
|---|
| Status | Akzeptiert |
|---|
| VulDB Eintrag | 365392 [SourceCodester Indian Invoicing System 1.0 Invoice Generation IGST_Invoice.php customer_name/category SQL Injection] |
|---|
| Punkte | 20 |
|---|