首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何防范XSS攻击

如何防范XSS攻击
EN

Stack Overflow用户
提问于 2013-05-24 20:21:32
回答 1查看 1.3K关注 0票数 2

渗透测试小组告诉我,下面的URL导致了XSS攻击-

id=0&id=1369413198709cUjxb8IRCtTJcbYBHb0Qiph&id=1369413198709cUj

这是我的download_msg.jsp代码

代码语言:javascript
复制
        <% String download_msg = null;
           if (session == null || session.getAttribute("user") == null) {
               download_msg = "Error message";
           } else {
               download_msg =
              (OLSUser)session.getAttribute("user")).getReportInfo().getDownloadMsg();
           } 
        %>

       <html>
        <head>
         <SCRIPT LANGUAGE='JavaScript' SRC='/Test/test.js'></SCRIPT>
           <SCRIPT LANGUAGE='JavaScript'>init('StmsReps');</SCRIPT>
             <script language="JavaScript">
            function redirect() {
             if (window.focus)
            self.focus();
         this.location = "/test/DownloadReport?<%=request.getQueryString()%>";
    }
        </script>
     <title>XSS</title>
     </head>
      <body marginwidth='0' marginheight='0' onload='javascript:redirect()'>
         <table width='90%' height='100%' align='center' border='0' cellspacing='0'
            cellpadding='0'>               
      <tr>
    <td align='center' class='header2'> <%= download_msg %></td>
   </tr>
   </table>
   </body>
   </html>

我发现jstl可以处理XSS攻击。你能告诉我,如果做下面的事情,那会好吗?或者我需要做其他的事情?

代码语言:javascript
复制
         <c:out value="<%= download_msg %>" escapeXml="true"/>
EN

回答 1

Stack Overflow用户

发布于 2013-05-24 21:11:41

不是的。这是不够的

代码语言:javascript
复制
this.location = "/test/DownloadReport?<%=request.getQueryString()%>";

攻击者可能能够发送具有如下所示的查询字符串的链接

代码语言:javascript
复制
?</script><script>alert(1337)//

代码语言:javascript
复制
?%22/alert('Pwned')

对于那些可能点击链接并执行嵌入式代码的天真用户来说。

您必须在不受信任的输入被插入到模板的任何地方应用适当的转义策略。

显然,我不能根据您的设置测试这些字符串,而且如果您用它们进行测试,它们可能无法工作,因为浏览器通常会对查询字符串进行一些规范化,但是您不应该依赖它来保护您免受查询字符串中HTML元字符的影响。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16743043

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档