无名[] 2023-03-03 17:07 采纳率: 23.8%
浏览 65
已结题

如何防止HTTP响应截断攻击

如何防止HTTP响应截断攻击
问题代码如下

response.setHeader("Content-dis","attache;filename=" + filename);

请问各位如何对这个做处理,排除\r \n

  • 写回答

3条回答 默认 最新

  • 编程漫步者 2023-03-04 11:18
    关注

    对于上述代码中的response.setHeader("Content-dis","attache;filename=" + filename);语句,我们可以采用以下方式对filename进行过滤和编码:

    String cleanFilename = filename.replaceAll("[\\r\\n]", "");
    response.setHeader("Content-disposition", "attachment;filename=\"" + cleanFilename + "\"");
    

    这里使用了Java中的replaceAll方法,将filename中的所有\r和\n字符替换为空字符串,从而排除了可能被攻击者利用的特殊字符。在设置响应头时,我们还需要将filename用双引号括起来,并将整个Content-disposition头部值写成一个字符串常量,这样可以防止攻击者在响应头中注入额外的内容。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月14日
  • 已采纳回答 3月6日
  • 创建了问题 3月3日

悬赏问题

  • ¥15 springboot 3.0 实现Security 6.x版本集成
  • ¥15 PHP-8.1 镜像无法用dockerfile里的CMD命令启动 只能进入容器启动,如何解决?(操作系统-ubuntu)
  • ¥15 请帮我解决一下下面六个代码
  • ¥15 关于资源监视工具的e-care有知道的嘛
  • ¥35 MIMO天线稀疏阵列排布问题
  • ¥60 用visual studio编写程序,利用间接平差求解水准网
  • ¥15 Llama如何调用shell或者Python
  • ¥20 谁能帮我挨个解读这个php语言编的代码什么意思?
  • ¥15 win10权限管理,限制普通用户使用删除功能
  • ¥15 minnio内存占用过大,内存没被回收(Windows环境)