前提
本記事 -08ログイン・ログアウトの実装に従ってハンズオンでコードを書いています。
SpringSecurity5.7より、extendsされているWebSecurityConfigurerAdapterがdeprecatedされます。
本記事のパスワード照会部分では
java
@EnableWebSecurity@RequiredArgsConstructorpublic class SecurityConfig extends WebSecurityConfigurerAdapter { private final UserDetailsManager userDetailsManager; private final PasswordEncoder passwordEncoder; @Override public void configure(HttpSecurity http) throws Exception { http.authorizeRequests() .antMatchers("/h2-console/**").hasRole("ADMIN") .antMatchers("/board").hasRole("USER") .and().formLogin() .loginPage("/user").permitAll() // ログインページのカスタマイズ .defaultSuccessUrl("/board") // ログイン認証ページの要求, ログイン成功後デフォルト画面の設定 .and().csrf().ignoringAntMatchers("/h2-console/**") .and().headers().frameOptions().sameOrigin(); } @Override protected void configure(AuthenticationManagerBuilder auth) throws Exception { auth.userDetailsService(userDetailsManager).passwordEncoder(passwordEncoder); } @Override public void configure(WebSecurity web) throws Exception { // Configure a new SecurityChainFilter web.ignoring().requestMatchers(PathRequest.toStaticResources().atCommonLocations()); } }
と表記されているため、SpringSecurity5.7~の表記に変えて実装を行いたいです。
実現したいこと
発生している問題・エラーメッセージ
実装方法に見当がつきません。
該当のソースコード
java
// root/config/SecurityConfig.java@EnableWebSecuritypublic class SecurityConfig { private final UserDetailsManager userDetailsManager; private final PasswordEncoder passwordEncoder; // configure(HttpSecurity http) @Bean public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception { http.authorizeRequests().antMatchers("/h2-console/**").hasRole("ADMIN") .antMatchers("/board").hasRole("USER") .and().formLogin() .loginPage("/user").permitAll() .defaultSuccessUrl("/board") .and().csrf().ignoringAntMatchers("/h2-console/**") .and().headers().frameOptions().sameOrigin(); return http.build(); } // configure(AuthenticationManagerBuilder auth) // configure(WebSecurity web) @Bean public WebSecurityCustomizer webSecurityCustomizer() { return (web) -> web.ignoring().requestMatchers( PathRequest.toStaticResources().atCommonLocations()); }}
java
// root/infrastracture/datasource/Config/DatasourceConfig.java@Configuration@RequiredArgsConstructorpublic class DatasourceConfig { private final DataSource dataSource; @Bean public UserDetailsManager userDetailsManager() { return new JdbcUserDetailsManager(dataSource); } @Bean public PasswordEncoder passwordEncoder() { return PasswordEncoderFactories.createDelegatingPasswordEncoder(); }}
試したこと
補足情報(FW/ツールのバージョンなど)
xml
<!-- pom.xml --><?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.7.2</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.example</groupId> <artifactId>ashitaba-hands-on</artifactId> <version>0.0.1</version> <name>ashitaba-hands-on</name> <description>[https://zenn.dev/angelica/books/52be1e365c61ea]の実践</description> <properties> <java.version>17</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> <!-- Tymleafのlayout --> <dependency> <groupId>nz.net.ultraq.thymeleaf</groupId> <artifactId>thymeleaf-layout-dialect</artifactId> </dependency> <!-- validationしたいので --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-validation</artifactId> </dependency> <!-- DB --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.4</version> </dependency> <dependency> <groupId>org.mybatis.scripting</groupId> <artifactId>mybatis-thymeleaf</artifactId> <version>1.0.2</version> </dependency> <dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> <version>1.4.200</version> <!--<scope>test</scope> 本来テストスコープだけで使うべき--> </dependency> <!-- セキュリティー --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <configuration> <excludes> <exclude> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> </exclude> </excludes> </configuration> </plugin> </plugins> </build> </project>

0 コメント