我正在閱讀一個彈簧安全教程,我正在嘗試使用如下類的 spring-boot-starter-security 配置基本安全性
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
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;
import org.springframework.security.crypto.password.NoOpPasswordEncoder;
@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
http.authorizeRequests().antMatchers("/","/api/*").permitAll()
.anyRequest().authenticated().and().formLogin().loginPage("/login").permitAll()
.and().logout().permitAll();
}
@Autowired
public void ConfigureGlobal(AuthenticationManagerBuilder auth) throws Exception {
auth.inMemoryAuthentication().passwordEncoder(NoOpPasswordEncoder.getInstance())
.withUser("user").password("password").roles("USER");
}
}
但是當我嘗試使用頁面 localhost:8080 或 localhost:8080/api/hello?name=test 時,它不會要求登錄并直接顯示請求的頁面。請幫我解決這個問題。
uj5u.com熱心網友回復:
代碼允許在沒有身份驗證的情況下訪問 / 和 /api/*
http.authorizeRequests().antMatchers("/","/api/*").permitAll()
它將未經身份驗證的訪問限制為與上述 url 不匹配的任何請求
.anyRequest().authenticated()
轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/459161.html
上一篇:如何從SpringStatemachine中獲取當前子狀態和父狀態?
下一篇:osboot.SpringApplication:Applicationrunfailed//我在這個網上看到了答案,但他們沒有幫助我
