反射型xss靶场练习

作者 : admin 本文共2791个字,预计阅读时间需要7分钟 发布时间: 2024-06-10 共2人阅读

反射型xss危害小,这里使用的xss靶场是常用的xss靶场:xss-labs。

当我们完成弹窗后就通过该关卡,说该关卡存在xss的一个漏洞并且可以解析js代码。

第一关:
 

这里没有过滤我们输入的代码:直接将js代码放在js代码中,js代码被执行。

反射型xss靶场练习插图

反射型xss靶场练习插图(1)

第二关:
 

在这里,对我们的输入的keyword值使用htmlspecialchars 函数进行了过滤,对 ‘ “ & 进行了实体编码。虽然可以对其进行解码,但是再不会进入到标签开始状态了,所以如果直接写并不会触发。

反射型xss靶场练习插图(2)

所以,我们在h2中无法进行操作了,我们需要在input中进行操作。

解法1:闭合input标签

    ">

反射型xss靶场练习插图(3)

解决方法2:闭合双引号,添加一个点击事件。

反射型xss靶场练习插图(4)

第二个方法需要用户点击输入框后才会执行,所以没有第一个方法好。

第三关:


ini_set("display_errors", 0);
$str = $_GET["keyword"];
echo "

没有找到和".htmlspecialchars($str)."相关的结果.

"." ";

在h2中对进行了实体编码,所以不考虑。只考虑Input中。观察在input中也是用了htmlspecialchars进行编码,并且在这里为 ’ (单引号)闭合。

我们去php官网查看这个函数发现:如果你要对单引号进行编码需要设置 ENT_QUOTES ,但这里并没有设置说明对单引号不起作用。

反射型xss靶场练习插图(5)

解决方法:

	

反射型xss靶场练习插图(6)

第四关:

$str = $_GET["keyword"];
$str2=str_replace(">","",$str);
$str3=str_replace("<","",$str2);
echo "

没有找到和".htmlspecialchars($str)."相关的结果.

".' ';

这里过滤了 ,所以无法闭合尖括号产生新标签。并且还使用htmlspecialchars在h2中进行过滤。所以只看Input。

解决方法:

反射型xss靶场练习插图(7)

第五关:
 

ini_set("display_errors", 0);
$str = strtolower($_GET["keyword"]);
$str2=str_replace(" 标签可以不区分大小写。比如写为:
但是在其中的内容要严格区分大小写,比如alert等。

解决方法:

asd" > asd 
 asd ">

反射型xss靶场练习插图(8)

第八关:

<?php 
ini_set("display_errors", 0);
$str = strtolower($_GET["keyword"]);
$str2=str_replace("script","scr_ipt",$str);
$str3=str_replace("on","o_n",$str2);
$str4=str_replace("src","sr_c",$str3);
$str5=str_replace("data","da_ta",$str4);
$str6=str_replace("href","hr_ef",$str5);
$str7=str_replace('"','&quot',$str6);
echo '




';
?>
<?php
 echo '
友情链接'; ?> 反射型xss靶场练习插图(9)

将实体进行输入到href中:

javascript:alert(12)
javascript:alert(12)

友情链接

反射型xss靶场练习插图(10)

第九关:
 

ini_set("display_errors", 0);
$str = strtolower($_GET["keyword"]);
$str2=str_replace("script","scr_ipt",$str);
$str3=str_replace("on","o_n",$str2);
$str4=str_replace("src","sr_c",$str3);
$str5=str_replace("data","da_ta",$str4);
$str6=str_replace("href","hr_ef",$str5);
$str7=str_replace('"','&quot',$str6);
echo '




';
?>
<?php
if(false===strpos($str7,'http://'))
{
  echo '
友情链接'; } else { echo '
友情链接'; }

这里的过滤和前面类似,但是在后面存在一个strpos函数,用来检测我们传的参数中是否有http://,如果有则合法,如果没有则不和法。

解决方法:

依然将javascript进行实体编码,不过还需要在后加上http://。

javascript:alert(112);//http://
javascript:alert(112);//http://
注意:在这里我们使用//将http://注释掉了,虽然注释掉了但是http://还是存在,所以检测时我们的输入是合法的。


友情链接

反射型xss靶场练习插图(11)

第十关:
 

$str = $_GET["keyword"];
$str11 = $_GET["t_sort"];
$str22=str_replace(">","",$str11);
$str33=str_replace("<","",$str22);
echo "

没有找到和".htmlspecialchars($str)."相关的结果.

".' ';

我们查看页面源代码发现存在隐藏的from表单:其中的input选项被隐藏了。

反射型xss靶场练习插图(12)

经过对php的源码分析发现:接收了一个t_sort参数,最后传递给表单中name=t_sort的输入框,所以我们可以在这里进行操作。这里过滤了 。

解决方法:

我们可以在url中给t_sort进行赋值,改变input的属性,改变之后就可以显示出来,当我们点击输入框时它就会弹窗。

/level10.php?t_sort=aaa" type="text" onclick="alert(12)

反射型xss靶场练习插图(13)

第十一关:
 

$str = $_GET["keyword"];
$str00 = $_GET["t_sort"];
$str11=$_SERVER['HTTP_REFERER'];
$str22=str_replace(">","",$str11);
$str33=str_replace("<","",$str22);
echo "

没有找到和".htmlspecialchars($str)."相关的结果.

".' ';

加了过滤函数htmlspecialchars的基本不用看了,我们只需要在观察即可。

$str11=$_SERVER['HTTP_REFERER']; 它获取的是我们http请求头的referer字段。

http中referer字段的含义:

referer可以跟踪你上网的痕迹,你从哪个网站跳转到另一个网站,它就会跟踪到。上面显示的是你从哪个网站过来的。

解决方法:伪造referer字段。

反射型xss靶场练习插图(14)

当我们点击输入框后就会弹窗:

反射型xss靶场练习插图(15)

第十二关:

伪造user agent

反射型xss靶场练习插图(16)

第十三关:

伪造cookies

本站无任何商业行为
个人在线分享 » 反射型xss靶场练习
E-->