java403forbidden_java – Spring boot – 返回403 Forbidden而不是重定向到登录页面

在Spring Boot Web应用程序中,我有以下安全配置:

@Override

public void configure(HttpSecurity http) throws Exception {

// @formatter:off

http

.headers().frameOptions().disable()

.and()

.antMatcher("/**").authorizeRequests()

.antMatchers("/actuator/health").permitAll()

.antMatchers("/actuator/**").hasAuthority(Authority.Type.ROLE_ADMIN.getName())

.antMatchers("/login/**").permitAll()

.anyRequest().authenticated()

.and()

.formLogin()

.loginPage("/login")

.loginProcessingUrl("/login")

.failureUrl("/login?error").permitAll()

.and()

.logout()

.logoutRequestMatcher(new AntPathRequestMatcher("/logout"))

.logoutSuccessUrl("/login?logout")

.and()

.csrf().csrfTokenRepository(csrfTokenRepository())

.and()

.addFilterAfter(csrfHeaderFilter(), CsrfFilter.class)

.addFilterBefore(ssoFilter(), BasicAuthenticationFilter.class);

// @formatter:on

}

现在,当我尝试访问例如以下url:/api/v1.0/user时,它会将我重定向到/ api / login页面.

如何配置这个以便返回403 Forbidden而不是重定向到登录页面?

解决方法:

这是一个社区答案:

问题:

禁止的URL返回登录页面内容(而不是403状态代码).

我有这个代码:

...

http.authorizeRequests().antMatchers("/uri/**").hasAuthority("SOME_ROLE");

改变了Tong的建议:

...

http.exceptionHandling().authenticationEntryPoint(new Http403ForbiddenEntryPoint());

http.authorizeRequests().antMatchers("/uri/**").hasAuthority("SOME_ROLE");

标签:java,spring-mvc,spring,spring-security,spring-boot-2

来源: https://codeday.me/bug/20190623/1269321.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值