質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Spring Security

Spring Securityは、Springのサブプロジェクトの一つでWebアプリケーションに必要な機能を追加します。正規ユーザーであるかを確認するための「認証機能」と、ユーザーのアクセスを制御する「認可機能」を簡単に追加することが可能です。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

Thymeleaf

Thymeleaf(タイムリーフ)とは、Java用のテンプレートエンジンで、特定のフレームワークに依存せず使用することが可能です。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

Q&A

解決済

2回答

3834閲覧

SpringSecurityでログイン機能を動作させるとstaticフォルダにアクセスできない。

spring_boot

総合スコア12

Spring Security

Spring Securityは、Springのサブプロジェクトの一つでWebアプリケーションに必要な機能を追加します。正規ユーザーであるかを確認するための「認証機能」と、ユーザーのアクセスを制御する「認可機能」を簡単に追加することが可能です。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

Thymeleaf

Thymeleaf(タイムリーフ)とは、Java用のテンプレートエンジンで、特定のフレームワークに依存せず使用することが可能です。

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

0グッド

0クリップ

投稿2018/09/30 01:56

SpringSecurityによるログイン認証機能のためstaticフォルダにアクセスできなくなりました。
いろいろと修正を試しましたが読み込みに成功しません。ぜひともご意見いただけるとありがたいです。

現在のファイル配置は
イメージ説明
以上のようになっています。

ログイン認証取り付け前は

java

1<link th:href="@{/css/color.css}" rel="stylesheet"/>

上記コードのようにアクセスすれば良かったのでアクセスさきはこのままでよいと思います。
HTMLとして書き出されるとhttp://localhost:8080/css/colorになります。

SpringSecurityによるログイン認証設置後にstaticフォルダにアクセスできなくなりました。
HTMLからのリンク、直接のアクセスどちらも失敗します。

WebSecurityConfigurerAdapterを継承したクラスは以下のように設定しています。

DemoSecurityConfig.java

java

1@Configuration 2@EnableWebSecurity 3public class DemoSecurityConfig extends WebSecurityConfigurerAdapter { 4 5 @Autowired 6 private UserInfoService userInfoService; 7 8 @Override 9 protected void configure(AuthenticationManagerBuilder auth) throws Exception { 10 //独自認証を設定 11 auth.authenticationProvider(createAuthProvider()); 12 13 } 14 15 private AuthenticationProvider createAuthProvider() { 16 DaoAuthenticationProvider authProvider = new DaoAuthenticationProvider(); 17         //user_infoテーブルのemailとpasswordで判定 18 authProvider.setUserDetailsService(userInfoService); 19 authProvider.setPasswordEncoder(new BCryptPasswordEncoder()); 20 21 return authProvider; 22 } 23 24 @Override 25 protected void configure(HttpSecurity http) throws Exception { 26 27 http.authorizeRequests() 28 .antMatchers("/register/**").permitAll()//**はそれより下の階層全て 29 .anyRequest().authenticated() 30 .and() 31 .formLogin() 32 .loginPage("/showMyLoginPage") 33 .loginProcessingUrl("/authenticateTheUser") 34 .permitAll() 35 .and() 36 .logout().permitAll() 37 .and() 38 .exceptionHandling().accessDeniedPage("/access-denied"); 39 40 } 41 42 @Override 43 public void configure(WebSecurity web) { 44         //ログイン認証前でもアクセスできるように設定できるらしいが動作していない 45 web.ignoring().antMatchers("/css/**", "/js/**", "/img/**","/bootstrap/**"); 46 } 47 48} 49

また、WebMvcConfigurerを実装したクラスは以下のようになっています。
WebMvcConfig.java

java

1@Configuration 2public class WebMvcConfig implements WebMvcConfigurer { 3 4 @Override 5 public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) { 6    //デフォルトルートパスを使用 7 configurer.enable(); 8 } 9 10 @Override 11 public void addResourceHandlers(ResourceHandlerRegistry registry) { 12    //ハンドラーでstaticコンテンツにアクセスできるようにする 動作していない 13 registry.addResourceHandler("/resources/**").addResourceLocations("/resources/"); 14 // to serve static .html pages... 15 registry.addResourceHandler("/static/**").addResourceLocations("/resources/static/"); 16 } 17}

SpringSecurityを動作させたときにスタティックコンテンツにアクセスするにはこのほかにどのような設定が必要でしょうか。もしくはコードに間違いがあるのでしょうか。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/09/30 05:19

なんとなくだが DemoSecurityConfig を実装してからじゃなく、WebMvcConfig を実装してからじゃね
guest

回答2

0

CSSやJavascriptだからといって SpringSecurityの対象外になるわけではないので認証が不要なら明示的に指定する必要があります。

http.authorizeRequests().antMatchers("/css/**","/js/**","/img/**").permitAll();

ですね

投稿2018/09/30 03:53

euledge

総合スコア2404

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

spring_boot

2018/09/30 05:13

ありがとうございます。 試してみたのですがantMatchers()ではアクセスできないようです。 こちらはControllerのマッピングに対応するものでしょうか。 解決法が見つかりましたので質問に追加しておきます。 ご回答誠にありがとうございました!
euledge

2018/09/30 05:19

解決できて良かったです。
spring_boot

2018/09/30 05:24

いただいたアイデアも参考になりました! ドキュメントが頼りなく(?)何が正解か分からないのですべて動作させてみないと分かりませんでした。 Spring MVCの中ではResourceHandlerRegistryを使うのが正攻法のようです。
退会済みユーザー

退会済みユーザー

2018/09/30 05:30

基本それ不要だけどね、以下で標準実装している。 WebSecurityConfigurerAdapter#configure(WebSecurity web) ちなみに「404 エラー」、「401エラー」で先に見分ける必要がある。
spring_boot

2018/09/30 05:45

ご回答ありがとうございます。 configurer.enable();は無くても動作しました。 registry.addResourceHandler("/**").addResourceLocations("/resources/static/"); こちらは加えておかないと404が発生してしまいます。
退会済みユーザー

退会済みユーザー

2018/09/30 06:46

クラス内の記述を削除じゃなくクラス自体を消してみそ
spring_boot

2018/09/30 07:09

WebMvcConfigをクラスファイルごと消しましたが、staticフォルダ内が読みこめなくなりました。 もともとここからのスタートだったので。本来、WebSecurityConfigurerAdapterの継承で十分なんですね。他で設定をいじっていないのですが何故か読み込みができません。
spring_boot

2018/09/30 15:14

なるほど!ありがとうございます。 明日再び調べて解決策を修正しておきます。
guest

0

自己解決

解決しました。

java

1@Configuration 2public class WebMvcConfig implements WebMvcConfigurer { 3 4 @Override 5 public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) { 6 configurer.enable(); 7 } 8 9 @Override 10 public void addResourceHandlers(ResourceHandlerRegistry registry) { 11 12 registry.addResourceHandler("/**").addResourceLocations("/resources/static/"); 13 } 14}

あと一歩のところまで来ていたようです。
addResourceHandler("/static/**")にしてしまうと、リンクにstaticを含めなくてはならなくなるので取り除きました。これで動作しました。

DispatcherServletとデフォルトサーブレットの併用

上記記事が関係しているようです。

投稿2018/09/30 05:21

spring_boot

総合スコア12

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/09/30 05:31

ちなみに、正答はそのクラスを実装しない
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問