2006-08-17 23:36:35 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
header('Content-type: text/html; charset=UTF-8');
|
|
|
|
|
|
|
|
?><!DOCTYPE html
|
2006-08-14 03:40:51 +00:00
|
|
|
PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
|
|
|
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
|
|
<html>
|
|
|
|
<head>
|
2006-08-17 23:36:35 +00:00
|
|
|
<title>HTMLPurifier XSS Attacks Smoketest</title>
|
|
|
|
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
2006-08-14 03:40:51 +00:00
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<h1>HTMLPurifier XSS Attacks Smoketest</h1>
|
2006-08-15 12:59:41 +00:00
|
|
|
<p>XSS attacks are from
|
|
|
|
<a href="http://ha.ckers.org/xss.html">http://ha.ckers.org/xss.html</a>.</p>
|
2006-08-14 03:40:51 +00:00
|
|
|
<p>The last segment of tests regarding blacklisted websites is not
|
|
|
|
applicable at the moment, but when we add that functionality they'll be
|
|
|
|
relevant.</p>
|
2006-08-17 23:36:35 +00:00
|
|
|
<p>Most of the XSS broadcasts its presence by spawning an alert dialogue.</p>
|
|
|
|
<h2>Test</h2>
|
2006-08-14 03:40:51 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
if (version_compare(PHP_VERSION, '5', '<')) exit('<p>Requires PHP 5.</p>');
|
|
|
|
|
|
|
|
set_include_path('../library' . PATH_SEPARATOR . get_include_path());
|
|
|
|
require_once 'HTMLPurifier.php';
|
|
|
|
|
|
|
|
$xml = simplexml_load_file('xssAttacks.xml');
|
|
|
|
$purifier = new HTMLPurifier();
|
|
|
|
|
|
|
|
?>
|
2006-08-17 23:36:35 +00:00
|
|
|
<!-- form is used so that we can use textareas and stay valid -->
|
2006-08-14 03:40:51 +00:00
|
|
|
<form method="post" action="xssAttacks.php">
|
|
|
|
<table>
|
|
|
|
<thead><tr><th>Name</th><th width="30%">Raw</th><th>Output</th><th>Render</th></tr></thead>
|
|
|
|
<tbody>
|
|
|
|
<?php
|
|
|
|
|
|
|
|
foreach ($xml->attack as $attack) {
|
2006-08-15 22:03:04 +00:00
|
|
|
$code = $attack->code;
|
|
|
|
// custom code for US-ASCII, which couldn't be expressed in XML without encoding
|
|
|
|
if ($attack->name == 'US-ASCII encoding') $code = urldecode($code);
|
2006-08-14 03:40:51 +00:00
|
|
|
?>
|
|
|
|
<tr>
|
|
|
|
<td><?php echo htmlspecialchars($attack->name); ?></td>
|
2006-08-15 22:03:04 +00:00
|
|
|
<td><textarea readonly="readonly" cols="20" rows="2"><?php echo htmlspecialchars($code); ?></textarea></td>
|
|
|
|
<?php $pure_html = $purifier->purify($code); ?>
|
2006-08-14 03:40:51 +00:00
|
|
|
<td><textarea readonly="readonly" cols="20" rows="2"><?php echo htmlspecialchars($pure_html); ?></textarea></td>
|
|
|
|
<td><?php echo $pure_html ?></td>
|
|
|
|
</tr>
|
|
|
|
<?php
|
|
|
|
}
|
|
|
|
|
|
|
|
?>
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</form>
|
|
|
|
</body>
|
|
|
|
</html>
|