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

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

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

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

Spring

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

Q&A

1回答

7551閲覧

SpringSecurityで複数ページでの認証の実装

teru1415

総合スコア12

Java

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

Spring

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

0グッド

3クリップ

投稿2015/05/17 08:33

編集2015/05/17 08:37

SpringSecurityを使用し、複数のログイン画面での認証は可能でしょうか。

サンプル等を拝見しても認証に使用する画面は一つだけで、情報取得に用いるテーブルも1つだけを指定しています。

例えばこれを、

・ユーザが利用者用ログインページにアクセスして認証を試みた場合は、利用者情報が格納されている利用者テーブルから認証を行う。
・ユーザが管理者専用ログインページにアクセスして認証を試みた場合は、管理者情報が格納された管理者テーブルから照合を行う。

認証後、利用者であるか管理者であるかの情報を付加した状態で認証状態を維持する。

という風にできないでしょうか?

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

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

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

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

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

guest

回答1

0

結構前の質問ですが…

@Orderを用いて2つのセキュリティclassを作成、
Serviceの方では別のテーブルを指定するようにすることでできるみたいですね…
(試してはないんです。)

java

1@Configuration 2@EnableWebMvcSecurity 3public class SecurityConfig { 4 5 @Configuration 6 @Order(1) 7 public static class FrontEndSecurityConfiguration extends WebSecurityConfigurerAdapter { 8 9 @Autowired 10 private PasswordEncoder passwordEncoder; 11 12 @Autowired 13 @Qualifier("frontend") 14 private UserDetailsService frontendUserDetailsService; 15 16 @Override 17 public void configure(AuthenticationManagerBuilder auth) throws Exception { 18 auth 19 .userDetailsService(frontendUserDetailsService) 20 .passwordEncoder(passwordEncoder); 21 } 22 23 @Override 24 protected void configure(HttpSecurity http) throws Exception { 25 http 26 .antMatcher("/frontend/**") 27 .authorizeRequests() 28 .anyRequest() 29 .hasRole("USER") 30 .and() 31 .formLogin(); 32 } 33 } 34 35 @Configuration 36 @Order(2) 37 public static class BackendSecurityConfiguration extends WebSecurityConfigurerAdapter { 38 39 @Autowired 40 private PasswordEncoder passwordEncoder; 41 42 @Autowired 43 @Qualifier("management") 44 private UserDetailsService managementUserDetailsService; 45 46 @Override 47 public void configure(AuthenticationManagerBuilder auth) throws Exception { 48 auth 49 .userDetailsService(managementUserDetailsService) 50 .passwordEncoder(passwordEncoder); 51 } 52 53 @Override 54 protected void configure(HttpSecurity http) throws Exception { 55 http 56 .antMatcher("/manage/**") 57 .authorizeRequests() 58 .anyRequest() 59 .hasRole("ADMIN") 60 .and() 61 .formLogin(); 62 } 63 } 64}

http://stackoverflow.com/questions/27571178/how-can-i-configure-spring-security-for-multiple-servlets

投稿2016/03/14 03:02

編集2016/03/14 03:04
kongbab04

総合スコア53

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問