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

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

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

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

Java

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

Q&A

0回答

3561閲覧

Java-SpringSecurityにて独自の二段階認証を行いたい

sakichan

総合スコア18

Spring Security

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

Java

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

0グッド

0クリップ

投稿2021/08/02 06:21

前提として、一段階目の認証はSpringSecurityを利用したパスワード認証を行います。
一段階目の認証が成功した場合に、ワンタイムパスワード等で二段階目の認証を自作したいと思っています。

問題として、一段階目の認証がSuccessした時点でセッションに認可情報が設定されるため、二段階目の認証画面よりURL直入力によるアクセスが行われた場合、Controllerでの認可が通ってしまいます。※ControllerにてROLE認証を行っている。
そこで、一段階目の認証では仮のROLEを設定しておき、二段階目の認証時に正しいロールで更新ができれば。と考えたのですが、更新方法がわかりません。
以下に試行イメージのソースを記載します。下記の@PreAuthorizeアノテーションではUserDetailsのコンストラクタで登録されたロールで認証されているようです。
正しい更新方法や、別の推奨のアプローチなどありましたら、ご教示をお願いします。

UserDetailsインタフェースの実装

java

1public class SampleUserDetails extends User { 2 public SampleUserDetails(Account account) { 3 super(account.getUsername(), account.getPassword(), AuthorityUtils 4 .createAuthorityList("ROLE_HOGE")); // 仮のロール 5 this.account = account; 6 }

ワンタイムパスワード認証コントローラ

java

1@Controller 2public class OnetimeController { 3 public String execute() throws Exception { 4 // 以下、試行コード 5 Authentication auth = SecurityContextHolder.getContext().getAuthentication(); 6 List<GrantedAuthority> updatedAuthorities = new ArrayList<>(auth.getAuthorities()); 7 updatedAuthorities.add(new SimpleGrantedAuthority("ROLE_ADMIN")); //正しいロール 8 Authentication newAuth = new UsernamePasswordAuthenticationToken(auth.getPrincipal(), auth.getCredentials(), updatedAuthorities); 9 SecurityContextHolder.getContext().setAuthentication(newAuth); 10 11121314 }

ログイン成功時に表示する画面のコントローラ

java

1@Controller 2public class HomeController { 3 @PreAuthorize("hasRole('ROLE_ADMIN')") // ロール制御(ワンタイムパスワード認証前では「access denied」となってほしい) 4 public String execute() throws Exception { 5678 }

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問