mirror of
https://github.com/elicpeter/nyx.git
synced 2026-06-21 20:18:06 +02:00
Dynamic (#77)
This commit is contained in:
parent
55247b7fcd
commit
991c84a1eb
1464 changed files with 225448 additions and 1985 deletions
24
tests/dynamic_fixtures/xpath_injection/php/benign.php
Normal file
24
tests/dynamic_fixtures/xpath_injection/php/benign.php
Normal file
|
|
@ -0,0 +1,24 @@
|
|||
<?php
|
||||
// Phase 07 (Track J.5) — PHP XPATH_INJECTION benign control fixture.
|
||||
//
|
||||
// Same shape as `vuln.php` but routes the attacker-controlled `$name`
|
||||
// through a small XPath-string-literal escape helper before splicing
|
||||
// it into the expression, so the selector stays pinned to a single
|
||||
// node.
|
||||
function nyx_xpath_escape($s) {
|
||||
if (strpos($s, "'") === false) {
|
||||
return "'" . $s . "'";
|
||||
}
|
||||
if (strpos($s, '"') === false) {
|
||||
return '"' . $s . '"';
|
||||
}
|
||||
return "concat('" . str_replace("'", "',\"'\",'", $s) . "')";
|
||||
}
|
||||
|
||||
function run($name) {
|
||||
$doc = new DOMDocument();
|
||||
$doc->load('xpath_corpus.xml');
|
||||
$xp = new DOMXPath($doc);
|
||||
$expr = "//user[@name=" . nyx_xpath_escape($name) . "]";
|
||||
return $xp->query($expr);
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue