低危漏洞修复——点击劫持X-Frame-Options响应头缺失

问题名称

X-Frame-Options响应头缺失,导致攻击者使用一个或多个透明的iframe覆盖在正常网页上,诱使用户在网页上进行操作,当用户在不知情的情况下点击透明的iframe页面时,用户的操作已被劫持到攻击者事先设计的恶意按钮或链接上

解决方案

设置 X-Frame-Options 响应头
在 Spring Boot 中可以通过配置 WebSecurityConfigurerAdapter 或者使用 Filter 来设置响应头

使用 WebSecurityConfigurerAdapter 配置类

import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;

@Configuration
@EnableWebSecurity
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http.headers()
                .frameOptions()
                .sameOrigin(); // 设置 X-Frame-Options 为 SAMEORIGIN
    }
}

使用 Filter 设置响应头

import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
import javax.servlet.*;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@Component
@Order(1)
public class AddResponseHeaderFilter implements Filter {

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
            throws IOException, ServletException {
        HttpServletResponse httpServletResponse = (HttpServletResponse) response;
        httpServletResponse.setHeader("X-Frame-Options", "SAMEORIGIN");
        chain.doFilter(request, response);
    }
}

设置 nginx 配置

#添加头文件
add_header X-Frame-Options SAMEORIGIN always;

修复验证:

image-20240711154957212

X-Frame-Options响应头的配置

X-Frame-Options 是一个 HTTP 响应头,允许网站控制是否允许页面在 <frame>, <iframe>, <embed><object> 中加载。通过设置 X-Frame-Options,可以指定以下三个值:

  1. DENY:表示页面不能在任何 frame 中显示,包括相同域名的页面。
  2. SAMEORIGIN:表示页面可以在相同域名页面的 frame 中显示。
  3. ALLOW-FROM uri:表示页面可以在指定来源的 frame 中显示。

为了防止点击劫持,建议设置 X-Frame-Options 响应头为 DENYSAMEORIGIN,具体选择取决于网站架构和需求

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-11 16:56:02       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-11 16:56:02       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-11 16:56:02       58 阅读
  4. Python语言-面向对象

    2024-07-11 16:56:02       69 阅读

热门阅读

  1. 差分进化算法

    2024-07-11 16:56:02       16 阅读
  2. 【Docker 入门】

    2024-07-11 16:56:02       25 阅读
  3. 从零手写实现 nginx-26-rewrite url 重写

    2024-07-11 16:56:02       22 阅读
  4. 虚拟化平台主流hypervisor工作原理分析

    2024-07-11 16:56:02       18 阅读
  5. 常用知识点问答

    2024-07-11 16:56:02       21 阅读
  6. SQL MySQL定时器/事件调度器(Event Scheduler)

    2024-07-11 16:56:02       24 阅读
  7. Unity 改造编辑器组件字段显示

    2024-07-11 16:56:02       24 阅读
  8. 解决selenium手动下载驱动问题

    2024-07-11 16:56:02       20 阅读
  9. 文本大模型下游任务与peft微调实战

    2024-07-11 16:56:02       20 阅读