微服务IFrame出Refused to display 'URL' in a frame because it set 'X-Frame-Options' to 'DENY'

IFrame出Refused to display 'URL' in a frame because it set 'X-Frame-Options' to 'DENY'

问题

在这里插入图片描述

原因

在这里插入图片描述
springboot+springsecurity导致以iframe形式来加载页面请求被拒绝。

X-Frame-Options值

DENY:表示该页面不允许在 frame 中展示,即便是在相同域名的页面中嵌套也不允许。
SAMEORIGIN:表示该页面可以在相同域名页面的 frame 中展示。
ALLOW-FROM uri:在指定来源的 frame 中展示。

解决办法

security配置类下添加http.headers().frameOptions().sameOrigin();

@Component
public class WebSecurityconfig extends WebSecurityConfigurerAdapter {

    /**
     * 引入Bcrypt加密会导致拦截所有微服务的请求要求登录,使用此放行请求
     * https://www.cnblogs.com/zbjj-itblog/p/10730619.html
     * @param http
     * @throws Exception
     */
    @Override
    protected void configure(HttpSecurity http) throws Exception {
        /**
         * authorizeRequests所有security全注解配置实现的开端,表示开始说明需要的权限
         * 第一部分是拦截的路径,第二部分表示需要的权限
         * 任何请求,认证后才能访问                                               ????????
         * 固定写法,表示使csrf拦截失效,一种网络攻击技术,初了内部请求其它都会失效
         */
                http
                .authorizeRequests()
                .antMatchers("/**").permitAll()
                .anyRequest().authenticated()
                .and().csrf().disable();
        http.headers().frameOptions().sameOrigin();//释放iframe下的子窗口加载

    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值