CRLF漏洞原理
参考:https://www.leavesongs.com/PENETRATION/Sina-CRLF-Injection.html
CRLF是”回车 + 换行”(\r\n)的简称。在HTTP协议中,HTTP Header与HTTP Body是用两个CRLF分隔的,浏览器就是根据这两个CRLF来取出HTTP 内容并显示出来。
漏洞利用
一旦我们能够控制HTTP消息头中的字符,注入一些恶意的换行,这样我们就能注入一些会话Cookie(http://www.xx.com%0a%0d%0a%0dSet-cookie:JSPSESSID%3Dxxx
)或者HTML代码(http://www.xx.com/?url=%0a%0d%0a%0d<img src=1 one rror=alert("xss")>
),所以CRLF Injection又叫HTTP Response Splitting,简称HRS。
浏览器的Filter是浏览器应对一些反射型XSS做的保护策略,当url中含有XSS相关特征的时候就会过滤掉不显示在页面中,所以不能触发XSS。
怎样才能关掉filter?一般来说用户这边是不行的,只有数据包中http头含有X-XSS-Protection并且值为0的时候,浏览器才不会开启filter。所以,可以将X-XSS-Protection:0注入到数据包中,再用两个CRLF来注入XSS代码,这样就成功地绕过了浏览器filter,并且执行我们的反射型XSS。
所以说HRS的危害大于XSS,因为它能绕过一般XSS所绕不过的filter,并能产生会话固定漏洞。
标签:XSS,浏览器,filter,nginx,CRLF,安全漏洞,HTTP,0a% From: https://www.cnblogs.com/smile2333/p/17053847.html