不可见(hidden)input标签触发XSS
在寻找XSS的过程中,会发现从POST或者URL中参数拿到INPUT中存放,但这些input都是hidden不可见的,通过F12调试,查看构造出来的代码确实存在点击事件,但是总是触发不了
通过网上查询资料,最总找到使用一个比较高级一点属性accesskey=""来触发不可见标签事件,accesskey是HTML语言标签中的一个全局属性
<input type="hidden" name="" accesskey="x" onclick="alert(/xss1/)">
使用方式:
提示: 各种浏览器下accesskey快捷键的使用方法:
IE浏览器
按住Alt键,点击accesskey定义的快捷键(焦点将移动到链接),再按回车.
FireFox浏览器
按住Alt+Shift键,点击accesskey定义的快捷键.
Chrome浏览器
按住Alt键,点击accesskey定义的快捷键.
Opera浏览器
按住Shift键,点击esc,出现本页定义的accesskey快捷键列表可供选择.
Safari浏览器
按住Alt键,点击accesskey定义的快捷键.
经过测试,只有FireFox通过。比较遗憾
最总解决方案思路
- F12 在控制台使用js代码通过dom定位input
- 使用js修改input type属性值为text,然后点击事件触发
<input type="hidden" id="xss" value="123" onclick="alert(/xss2/)">
控制台输入:
document.getElementById("xss").setAttribute("type","text");
其实更加高级一点就是将修改属性的那一步一并封装到input事件中,就是代码长了一点
在最近项目中遇到的是代码中可能使用了某种过滤规则,导致我输入<>或者(),只要走中间加入字母就会被拦截,无奈使用了跳转展现出来触发效果,使用了window.location.href='xxx'