XSS 和回显 <script> 标签
XSS and echoing <script> tags
我正在学习 XSS。但是,我在网上看到的大多数东西都是理论性的,我只是想看看实际情况。所以我有如下表格:
<?php
$input_xss=$_POST['input_xss'];
?>
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>The HTML5 Herald</title>
<meta name="description" content="The HTML5 Herald">
<meta name="author" content="SitePoint">
<link rel="stylesheet" href="css/styles.css?v=1.0">
</head>
<body>
<form action ="." method="POST">
<label for ="input_xss">Enter Text Here </label>
<input type="text" id="input_xss" name="input_xss" ><br/>
<?php echo $input_xss;?>
<input type="submit" value="SUBMIT">
</form>
</body>
</html>
我并不是有意清理输入以查看 XSS 的实际工作原理。所以,如果我输入类似
<b> This is bold </b>
我看到输出为粗体,因此输入未转义。但是,如果我输入
<script>alert('hi');</script>
虽然我在浏览器中看到源代码时看到 <script>alert("hi") ; </script>
,但我没有看到 Javascript 警报 window。有人能告诉我为什么 JS 警报 window 没有弹出吗?
这种微不足道的 xss 有时会被浏览器阻止。 Chrome 是我认为在这方面比其他人好一点。
您的示例对于浏览器来说很简单,因为来自页面参数的 javascript 会在页面 body 中回显,所以它不会是 运行。如果我没记错的话,你应该会收到一条关于它的控制台日志消息。
请注意,这只会阻止少量的 XSS 攻击,只有微不足道的攻击。
您可以通过 X-XSS-Protection: 0
响应 header 禁用此功能,但您应该只出于学习目的这样做。
我正在学习 XSS。但是,我在网上看到的大多数东西都是理论性的,我只是想看看实际情况。所以我有如下表格:
<?php
$input_xss=$_POST['input_xss'];
?>
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>The HTML5 Herald</title>
<meta name="description" content="The HTML5 Herald">
<meta name="author" content="SitePoint">
<link rel="stylesheet" href="css/styles.css?v=1.0">
</head>
<body>
<form action ="." method="POST">
<label for ="input_xss">Enter Text Here </label>
<input type="text" id="input_xss" name="input_xss" ><br/>
<?php echo $input_xss;?>
<input type="submit" value="SUBMIT">
</form>
</body>
</html>
我并不是有意清理输入以查看 XSS 的实际工作原理。所以,如果我输入类似
<b> This is bold </b>
我看到输出为粗体,因此输入未转义。但是,如果我输入
<script>alert('hi');</script>
虽然我在浏览器中看到源代码时看到 <script>alert("hi") ; </script>
,但我没有看到 Javascript 警报 window。有人能告诉我为什么 JS 警报 window 没有弹出吗?
这种微不足道的 xss 有时会被浏览器阻止。 Chrome 是我认为在这方面比其他人好一点。 您的示例对于浏览器来说很简单,因为来自页面参数的 javascript 会在页面 body 中回显,所以它不会是 运行。如果我没记错的话,你应该会收到一条关于它的控制台日志消息。
请注意,这只会阻止少量的 XSS 攻击,只有微不足道的攻击。
您可以通过 X-XSS-Protection: 0
响应 header 禁用此功能,但您应该只出于学习目的这样做。