html对标签%3ca%3e隐藏,XSS过滤绕过

事件处理器

不需要用户交互的可执行js的事件处理器:

onreadystatechange(xml,style,iframe,object,img,input,isindex,bground)

onpropertychange

onbeforeactivate

onfocusin

onactivate

注意:在HTML5中,结束标签中也可以使用事件处理器

脚本伪协议

脚本伪协议可以用在各种位置,在需要URL的属性中执行行内脚本,如:

标签名称

通过改变标签名称的大小写,可以避开最简单的过滤:

a

更进一步,可以在任何位置插入NULL字节:

或者,可以将标签作一改变,即可避开仅仅阻止特定标签名的过滤:

Click here

标签名称后的空格

可以使用:/,[%09],[%0d],[%0a],/”,/’来代替,如:

a

通过HTML编码绕过过滤(也可以使用十进制,十六进制)

使用HTML编码,在进一步处理属性值的时候,浏览器会对其进行HTML解码:

a

如果存在两次URL解码

可以通过构造:

%253cimg%20οnerrοr=alert(1)%20src=a%253e

第一次URL解码以后:

%3cimg οnerrοr=alert(1) src=a%3e

第二次URL解码以后:

a

字符集绕过

UTF-7,US-ASCII,UTF-16(这种方法只有在浏览器支持所用的字符集才可以,或者你可以控制HTTPContent-Type消息头)

使用js转义

Unicode转义可以用于表示js关键词中的字符

通过eval命令来动态构建字符串

替代eval的方法

``

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值