HTML5引入的新标签有一些有趣的属性,例如poster、autofocus、onerror、formaction、oninput,这些属性都可以用来执行javascript。这会导致XSS和CSRF跨域请求伪造。
HTML5去掉了很多过时的标签,例如<center>和<frameset>,同时又引入了许多有趣的新标签,例如<video>和<audio>标签可以允许动态的加载音频和视频。
HTML5引入的新标签包括<Audio>、<Video>、<Canvas>、<Article>、<Footer>等等,而这些标签又有一些有趣的属性,例如poster、autofocus、onerror、formaction、oninput,这些属性都可以用来执行javascript。这会导致XSS和CSRF跨域请求伪造。
这些关键载体允许创建XSS的变种并且可以绕过现有的XSS过滤器。
首先来看一个标签:
<video><sourceonerrorsourceonerrorsourceonerrorsourceonerror=”javascript:alert(1)“>
它使用了一个source标签,而没有指定具体的src,所以后面的onerror方法会立即得到执行。
下面是video的poster属性,它链接到一个图像,是指当视频未响应或缓冲不足时,显示的占位符。
<videopostervideopostervideopostervideoposter=”javascript:alert(1)”>
另外还有HTML5新引入的autofocus和formaction属性,autofocus会让元素自动的获取焦点,而formaction属性能覆盖 form 元素的action 属性。
[html] view plaincopyprint?
01.<inputautofocus onfocus=“alert(1)”>
02.<form><buttonformactionbuttonformactionbuttonformactionbuttonformaction=”javascript:alert(1)”>
在这个项目里存在用户输入的地方,虽然已经针对旧有的标签以及属性进行了过滤和清洗,但是还会存在新标签攻击的漏洞,攻击者利用上面的示例方式就可以对系统进行XSS注入攻击。例如攻击者输入http://www.trustauth.cn/1.php?text=<videoposter=”javascript:alert(1)”>时就能立即运行攻击脚本。
对此攻击的防御方式是,对前端或者后端的过滤器进行优化,添加过滤规则或者黑名单。
SSL证书是HTTP明文协议升级HTTPS加密协议的重要渠道,是网络安全传输的加密到通道。关于更多SSL证书的资讯,请关注GDCA(数安时代)。GDCA致力于网络信息安全,已通过WebTrust 的国际认证,是全球可信任的证书签发机构。GDCA专业技术团队将根据用户具体情况为其提供最优的产品选择建议,并针对不同的应用或服务器要求提供专业对应的HTTPS解决方案。