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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring

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

Q&A

解決済

1回答

1786閲覧

Springsecurityのログイン失敗時の画面遷移について

heavyuseman

総合スコア42

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring

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

1グッド

1クリップ

投稿2017/06/10 10:27

いつもお世話になっております。
Springsecurityのログイン失敗時の画面遷移について質問があります。
Springsecurityのjavaconfigファイル(SecurityConfig.java)でログインについての設定をしております。

java

1//SecurityConfig.java 2package com.tuyano.springboot.springsecurity; 3 4import org.springframework.context.annotation.Bean; 5import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder; 6import org.springframework.security.config.annotation.web.builders.HttpSecurity; 7import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity; 8import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter; 9import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; 10 11import javax.sql.DataSource; 12 13import org.springframework.beans.factory.annotation.Autowired; 14import org.springframework.beans.factory.annotation.Qualifier; 15 16 17 18@EnableWebSecurity 19public class SecurityConfig extends WebSecurityConfigurerAdapter{ 20 @Autowired 21 private DataSource dataSource; 22 23 private static final String USER_QUERY="select name, password, 1 from Newaccount where name = ?"; 24 private static final 25 String ROLES_QUERY="select username, authority from AUTHORITIES where username = ?"; 26 27 @Override 28 protected void configure(HttpSecurity http) throws Exception{ 29 http 30 .authorizeRequests() 31 .antMatchers("/First.html").permitAll() 32 .antMatchers("/templates/**").hasAnyAuthority("ROLE_ADMIN") 33 .anyRequest().authenticated() 34 .and() 35 .formLogin() 36 .loginPage("/First.html") 37 .loginProcessingUrl("/processLogin") 38 .defaultSuccessUrl("/sucess.html") 39 .failureUrl("/failure.html") 40 .usernameParameter("name") 41 .passwordParameter("password") 42 .and() 43 .logout() 44 .logoutUrl("/processLogout") 45 .logoutSuccessUrl("/First") 46 .and() 47 .csrf() 48 .disable(); 49 50 } 51 @Override 52 public void configure(AuthenticationManagerBuilder auth) throws Exception { 53 auth.jdbcAuthentication() 54 .dataSource(dataSource) 55 .usersByUsernameQuery(USER_QUERY) 56 .authoritiesByUsernameQuery(ROLES_QUERY); 57 //passwordEncoder(new BCryptPasswordEncoder()); 58 //.authoritiesByUsernameQuery( 59 // "select mail_address, role from accounts where mail_address = ?"); 60 } 61 62 63} 64

.failureUrl("/failure.html")でログイン失敗時は("/failure.html")に画面遷移するようにしているのですが、初期表示画面である/First.htmlに画面遷移してしまいます。
これはSpringsecurityの初期設定上、ログイン失敗時は初期表示画面である/First.htmlに画面遷移するようになっているということでしょうか?
それとも、私の実装上どこか誤っている箇所があり、画面遷移が正常にできていないのでしょうか。
ご回答のほど宜しくお願い致します。

A-pZ👍を押しています

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

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

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

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

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

guest

回答1

0

ベストアンサー

.anyRequest().authenticated() が有効であるため、この記述があった以降のリクエストについては、すべてのリクエストは認証済みでなけれはいけません。
※それが認証失敗時の画面遷移であってもログイン画面へ遷移します。

これを一部例外的に許可するには、First.htmlを全許可しているのと同様に、.anyRequest().authenticated() よりも先に failure.htmlの全許可設定をしておくと良いでしょう。

java

1protected void configure(HttpSecurity http) throws Exception{ 2 http 3 .authorizeRequests() 4 .antMatchers("/First.html").permitAll() 5 .antMatchers("/failure.html").permitAll() 6 .antMatchers("/templates/**").hasAnyAuthority("ROLE_ADMIN") 7 .anyRequest().authenticated() 8 .and() 9 .formLogin() 10(省略)11 }

投稿2017/06/10 16:02

A-pZ

総合スコア12011

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

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

heavyuseman

2017/06/11 07:19

ご回答ありがとうございます。上記の通りに対応したところ無事/failure.htmlに画面遷移しました。 ご対応ありがとうございました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問