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

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

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

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

Java

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

Spring

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

Q&A

解決済

1回答

4511閲覧

リダイレクトの無限ループについて

kisamaru

総合スコア6

Spring Security

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

Java

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

Spring

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

0グッド

0クリップ

投稿2020/05/21 11:40

ログイン画面で認証をした後、インターセプターを使用し
二段階認証のQRコードを表示する画面にリダイレクトし、QRコード画面にある「次へ」ボタンを
押下すると次の画面に行くという処理を行いたいのですが

QRコードの画面のボタンを押下すると
もう一度インターセプターのQRコードの画面を表示する処理へと無限ループしてしまいます。

以下該当ソース
●Intercepter

Java

1public class TwoFactorAuthenticationInterceptor implements HandlerInterceptor { 2 3 @Override 4 public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) 5 throws Exception { 6 7 if (handler instanceof ResourceHttpRequestHandler) { 8 return true; 9 } 10 11 String uri = request.getRequestURI(); 12 13 if (!uri.endsWith("twoFactorAuthentication/index")) { 14 response.sendRedirect( 15 "twoFactorAuthentication/index" 16 ); 17 } 18 return true; 19 } 20 21 @Override 22 public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, 23 ModelAndView modelAndView) throws Exception { 24 System.out.println("postHandle"); 25 } 26 27 @Override 28 public void afterCompletion(HttpServletRequest request, HttpServletResponse response, 29 Object handler, Exception ex) throws Exception { 30 System.out.println("afterCompletion"); 31 } 32 33} 34

●Controller

java

1 2@Validated 3@Controller 4public class TwoFactorAuthenticationController { 5 @Autowired 6 TwoFactorAuthenticationService twoFactorAuthenticationService; 7 8 @GetMapping("twoFactorAuthentication/index") 9 public String twoFactorAuthenticationIndex(String id,HttpSession session, 10 Model model) { 11 12 ~~QRコード作成処理~~ 13 14 } 15 return "twoFactorAuthentication/index"; 16 } 17 18 19 //QRコード画面でボタンを押下した時の画面呼び出し 20 @RequestMapping(value = "B111102", method = RequestMethod.POST) 21 public String twoFactorAuthenticationCode() { 22 return "twoFactorAuthentication/B111102"; 23 } 24} 25

●MvcConfig

java

1 @Override 2 public void addInterceptors(InterceptorRegistry registry) { 3 registry.addInterceptor(new TwoFactorAuthenticationInterceptor()).addPathPatterns("/**") 4 .excludePathPatterns("/login") 5 .excludePathPatterns("/") 6 .excludePathPatterns("/twoFactorAuthentication/index") ; 7 }

よろしければご教授いただけると幸いです。
宜しくお願い致します。

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

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

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

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

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

m.ts10806

2020/05/21 19:08

>.excludePathPatterns("/") これは何の意図で入れてますか? そのまま読むと全てに当てはまりそうに思いますが
kisamaru

2020/05/27 10:19

こちらは二段階認証後に遷移されるパスで意図的に入れています。
guest

回答1

0

ベストアンサー

仕様がわからないのでどうすれば正解かというのは回答できませんが、ループする原因は以下の通りです。

遷移が下記の通り(1) から (4)へ進むという前提で進めます。

(1) (2) (3) (4) / -> /login -> /twoFactorAuthentication/index -post-> /B111102

インターセプターが対象外とするのは、下記のコードにより(1)(2)(3)となります。つまり(4)へ遷移する場合はこのインターセプターの対象となります。

java

1registry.addInterceptor(new TwoFactorAuthenticationInterceptor()).addPathPatterns("/**") 2 .excludePathPatterns("/login") 3 .excludePathPatterns("/") 4 .excludePathPatterns("/twoFactorAuthentication/index");

次にインターセプター内ですが、下記コードの通りURIの末尾が"twoFactorAuthentication/index"でなければ、"/twoFactorAuthentication/index"へリダイレクトするという処理になっています。
このため(3) から (4)へ遷移するときにこの処理によって(3)へリダイレクトしている、ということが原因になります。

java

1String uri = request.getRequestURI(); 2if (!uri.endsWith("twoFactorAuthentication/index")) { 3 response.sendRedirect("twoFactorAuthentication/index"); 4}

投稿2020/05/21 23:22

rubytomato

総合スコア1752

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問