カテゴリ: Spring 更新日: 2026/03/17

Springの@EnableGlobalMethodSecurityを完全ガイド!初心者でもわかるメソッドセキュリティ設定

Springの@EnableGlobalMethodSecurityアノテーション
Springの@EnableGlobalMethodSecurityアノテーション

先生と生徒の会話形式で理解しよう

生徒

「先生、Springでメソッド単位のセキュリティを設定できる方法ってありますか?」

先生

「はい、Springでは@EnableGlobalMethodSecurityというアノテーションを使うことで、メソッド単位でのセキュリティを設定できるんです。」

生徒

「それって、どうやって設定するんですか?」

先生

「では、基本的な使い方を見ていきましょう!」

1. @EnableGlobalMethodSecurityとは?仕組みをわかりやすく解説

「1. @EnableGlobalMethodSecurityとは?仕組みをわかりやすく解説」の重要ポイントを、初心者の方にも分かりやすく簡潔に解説します。

1. @EnableGlobalMethodSecurityとは?仕組みをわかりやすく解説
1. @EnableGlobalMethodSecurityとは?仕組みをわかりやすく解説

@EnableGlobalMethodSecurityは、Spring Securityにおいて「メソッド単位でカギをかける機能」を有効にするための魔法のアノテーションです。

通常、Webサイトのセキュリティは「このURLには管理者だけがアクセスできる」というように、ページ(URL)単位で設定します。しかし、プログラムが複雑になると「この処理(メソッド)は店長だけ、この処理は店員もOK」といった、より細かい制御が必要になります。これを実現するのが「メソッドレベルのセキュリティ」です。

未経験者向けの例え話:
ホテルの入り口でチェックするのが「URLセキュリティ」なら、各部屋の金庫を開ける際に暗証番号を求めるのが「メソッドセキュリティ」です。たとえホテルの中に入れたとしても、権限がなければ金庫(メソッド)は開けられません。

この設定を有効にすると、以下のようなシンプルなプログラムでアクセス制限をかけられるようになります。


// イメージ:店長だけが実行できる「給料を支払う」メソッド
@Secured("ROLE_MANAGER")
public void paySalary() {
    // 給料を振込む大切な処理
    System.out.println("給料の支払いが完了しました。");
}

このように、@EnableGlobalMethodSecurityを使うことで、@Secured@PreAuthorizeといった便利な「目印(アノテーション)」が使えるようになり、ソースコードを見ただけで「誰がこの処理を実行できるのか」が一目でわかるようになります。

2. @EnableGlobalMethodSecurityの基本的な使い方

2. @EnableGlobalMethodSecurityの基本的な使い方
2. @EnableGlobalMethodSecurityの基本的な使い方

@EnableGlobalMethodSecurityは、Spring Securityで「メソッド単位のアクセス制限」を有効にするための魔法のスイッチのようなものです。Webページ全体ではなく、「このボタンを押した時の処理」や「データの保存処理」といった特定の動作に対して、個別にカギをかけることができます。

使い方は非常にシンプルで、Spring Bootの設定クラス(Configurationクラス)にこのアノテーションを記述するだけです。プログラミングが初めての方でも、まずは「設定ファイルに一行書き足すだけでセキュリティが強化される」とイメージすればOKです。


import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.method.configuration.EnableGlobalMethodSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;

@Configuration
@EnableWebSecurity
// ここでメソッドセキュリティを有効化します。securedEnabled = trueは@Securedを使うための設定です。
@EnableGlobalMethodSecurity(securedEnabled = true)
public class SecurityConfig {
    // アプリ全体のセキュリティルール(ログイン画面の表示など)をここに記述します
}

上記のコードで securedEnabled = true と指定することで、@Secured という仕組みが使えるようになります。これは「管理者(ADMIN)だけが実行できるメソッド」や「一般ユーザー(USER)ならOK」といったルールを、プログラムの各部分に直接メモ書き(アノテーション)のように残せる便利な機能です。

例えば、以下のような簡単なプログラムをイメージしてみてください。


import org.springframework.security.access.annotation.Secured;
import org.springframework.stereotype.Service;

@Service
public class UserService {

    // 「ROLE_ADMIN」という権限を持っている人だけが、このメソッド(処理)を動かせます
    @Secured("ROLE_ADMIN")
    public void deleteUser() {
        System.out.println("ユーザーを削除しました。");
    }
}

このように設定することで、万が一管理画面のURLが漏れてしまったとしても、権限のないユーザーが大事なデータ操作を実行しようとした瞬間にSpring Securityがブロックしてくれるようになります。初心者の方は、まず「設定クラスで有効化」し、「守りたい場所にアノテーションを貼る」という2ステップを覚えておきましょう。

3. @Securedアノテーションの活用例

3. @Securedアノテーションの活用例
3. @Securedアノテーションの活用例

@Securedアノテーションを使うことで、メソッドごとにアクセス権限を設定できます。以下の例では、管理者のみがアクセスできるメソッドを定義しています。


import org.springframework.security.access.annotation.Secured;
import org.springframework.stereotype.Service;

@Service
public class AdminService {

    @Secured("ROLE_ADMIN")
    public void performAdminTask() {
        System.out.println("管理者専用のタスクを実行中...");
    }
}

上記のperformAdminTaskメソッドは、ROLE_ADMIN権限を持つユーザーのみがアクセス可能です。
一般ユーザーがアクセスしようとすると、アクセスが拒否されます。

4. @PreAuthorizeアノテーションの利用

「4. @PreAuthorizeアノテーションの利用」の重要ポイントを、初心者の方にも分かりやすく簡潔に解説します。

4. @PreAuthorizeアノテーションの利用
4. @PreAuthorizeアノテーションの利用

@EnableGlobalMethodSecurityには他にも便利な機能があり、@PreAuthorizeアノテーションを使用することで、より柔軟な条件でアクセス制御が可能です。
例えば、以下のようにユーザー名に基づいたアクセス制御を行うことができます。


import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.stereotype.Service;

@Service
public class UserService {

    @PreAuthorize("hasRole('ADMIN') or #username == authentication.name")
    public void viewProfile(String username) {
        System.out.println(username + "のプロフィールを表示中...");
    }
}

ここでは、ADMINロールを持つユーザー、またはログインユーザーが自身のプロフィールにアクセスできるよう設定しています。
このように、@PreAuthorizeを使うと複雑なアクセス条件を簡単に指定できます。

5. Spring Bootアプリケーションでの利用シナリオ

5. Spring Bootアプリケーションでの利用シナリオ
5. Spring Bootアプリケーションでの利用シナリオ

例えば、社内システムやWebアプリケーションでは、管理者権限のあるユーザーのみが設定を変更できる、一般ユーザーは閲覧のみ可能にするなどの制御が必要です。
これをSpring Securityの@EnableGlobalMethodSecurityと各種アノテーションを使って実現できます。


import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.stereotype.Service;

@Service
public class ContentService {

    @PreAuthorize("hasRole('EDITOR')")
    public void editContent() {
        System.out.println("コンテンツを編集しています...");
    }

    @PreAuthorize("hasRole('USER')")
    public void viewContent() {
        System.out.println("コンテンツを表示中...");
    }
}

上記の例では、editContentメソッドは編集者のみが実行でき、viewContentメソッドは一般ユーザーが実行できます。
これにより、システム全体のセキュリティを強化することが可能です。

6. @EnableGlobalMethodSecurityの追加オプション

6. @EnableGlobalMethodSecurityの追加オプション
6. @EnableGlobalMethodSecurityの追加オプション

@EnableGlobalMethodSecurityには、securedEnabled以外にもいくつかのオプションがあります。

  • prePostEnabled - @PreAuthorize@PostAuthorizeの利用を有効にします。
  • jsr250Enabled - @RolesAllowedアノテーションの利用を有効にします。

これらを活用することで、セキュリティ設定をさらに柔軟に行うことが可能です。

7. まとめ

「7. まとめ」の重要ポイントを、初心者の方にも分かりやすく簡潔に解説します。

7. まとめ
7. まとめ

ここまで、Springの@EnableGlobalMethodSecurityアノテーションを使ったメソッド単位のセキュリティ設定について詳しく解説してきました。
このアノテーションを利用することで、メソッドごとにセキュリティルールを細かく設定でき、アプリケーションの安全性を向上させることができます。
例えば、管理者ユーザーのみが実行できる処理や、特定のロールを持つユーザーにのみ許可される機能など、セキュリティポリシーを柔軟にカスタマイズすることが可能です。

また、@Secured@PreAuthorize@PostAuthorizeといったアノテーションを組み合わせることで、より複雑なアクセス制御も実現できます。これにより、例えば管理者権限が必要な機能、編集者のみがアクセス可能な機能、一般ユーザーが利用できる機能など、アプリケーションの用途に応じたセキュリティ管理が可能です。

さらに、Spring Securityの@EnableGlobalMethodSecurityの各種オプション(securedEnabledprePostEnabledjsr250Enabled)を利用することで、セキュリティ設定の柔軟性が増し、アプリケーションのセキュリティ要件に合わせたきめ細かな制御が可能になります。

活用のポイント

  • システムの要件に合わせて、@Secured@PreAuthorizeを使い分ける。
  • セキュリティ設定を一元管理することで、変更に強い設計にする。
  • 開発段階で積極的にメソッドセキュリティを導入し、脆弱性を未然に防ぐ。

これらの設定を活用すれば、より堅牢でセキュアなSpring Bootアプリケーションの構築が可能です。
ぜひ、実際の開発で活用してみてください。

先生と生徒の振り返り会話

生徒

「Springの@EnableGlobalMethodSecurityを使うと、どういったメリットがあるんですか?」

先生

「メソッド単位で細かくアクセス制御ができるので、セキュリティの柔軟性が大幅に向上します。また、コード内でセキュリティポリシーを簡単に設定できるのもポイントです。」

生徒

@PreAuthorizeとか@Securedって、具体的にどう使い分けるんですか?」

先生

@Securedは単純なロールベースのチェックに便利で、@PreAuthorizeはより複雑な条件(ユーザー名のチェックや式の評価など)に対応できます。開発する機能に合わせて使い分けると良いですね。」

生徒

「確かに、それなら管理画面と一般ユーザー画面で役割を分けてアクセス制御できますね。」

先生

「そうです。その通りです。Spring Securityをうまく活用して、安全で効率的なシステムを作りましょう!」

この記事を読んだ人からの質問

この記事を読んだ人からの質問
この記事を読んだ人からの質問

プログラミング初心者からのよくある疑問/質問を解決します

@EnableGlobalMethodSecurityとは何ですか?

@EnableGlobalMethodSecurityは、Spring Securityでメソッド単位のセキュリティ設定を有効化するためのアノテーションです。このアノテーションを使うことで、@Securedや@PreAuthorizeなどのセキュリティアノテーションを有効にできます。

@EnableGlobalMethodSecurityを使うメリットは何ですか?

@EnableGlobalMethodSecurityを使うと、メソッド単位でアクセス制御を設定でき、システムのセキュリティを細かく管理できます。また、ユーザー権限に基づいた柔軟なセキュリティ設定が可能です。

@Securedアノテーションと@PreAuthorizeアノテーションの違いは何ですか?

@Securedは特定のロールに基づいたシンプルなアクセス制御を提供します。一方、@PreAuthorizeは式を使用してより複雑な条件を指定することができます。

@Securedを使った基本的な例を教えてください。

@Secured("ROLE_ADMIN")と記述することで、ROLE_ADMIN権限を持つユーザーのみがそのメソッドを実行できます。たとえば、管理者専用の機能に適用できます。

@PreAuthorizeアノテーションでどのような条件を指定できますか?

@PreAuthorizeを使うと、ロールのチェック(hasRole)やログインユーザーの名前チェック(authentication.name)など、複雑な条件を設定できます。

@EnableGlobalMethodSecurityのオプション設定にはどのようなものがありますか?

@EnableGlobalMethodSecurityには、securedEnabled(@Securedを有効化)、prePostEnabled(@PreAuthorizeや@PostAuthorizeを有効化)、jsr250Enabled(@RolesAllowedを有効化)などのオプションがあります。

@EnableGlobalMethodSecurityのprePostEnabledを有効にする方法を教えてください。

Spring Securityの設定クラスに@EnableGlobalMethodSecurity(prePostEnabled = true)を追加するだけで有効にできます。

@EnableGlobalMethodSecurityを使う際の注意点はありますか?

@EnableGlobalMethodSecurityを使う場合、セキュリティ設定がアプリケーション全体に影響するため、設定内容を適切に管理することが重要です。

@Securedと@RolesAllowedはどう使い分ければいいですか?

@SecuredはSpring Security独自のアノテーションで、@RolesAllowedはJSR-250標準のアノテーションです。プロジェクトの要件や利用する技術スタックに応じて選ぶと良いでしょう。

初心者がSpring Securityを学ぶ際の最初のステップは何ですか?

まずは、基本的なセキュリティ設定(@EnableGlobalMethodSecurityや@Secured)を理解し、シンプルなアクセス制御を試してみることから始めると良いでしょう。
カテゴリの一覧へ
新着記事
New1
Spring
Spring Securityの新標準!SecurityFilterChainとHttpSecurity DSLの書き方を初心者向けに解説
更新記事
New2
Java
Javaの抽象クラス(abstract)を完全ガイド!継承と設計のルールを学ぶ
更新記事
New3
Servlet
JavaのGenericServletクラスのgetInitParameterNamesメソッドを徹底解説!初心者でもわかる初期化パラメータの取得方法
更新記事
New4
JSP
JSPとは何か?初心者向けにできること・仕組み・特徴をやさしく解説
更新記事
人気記事
No.1
Java&Spring記事人気No1
Spring
Spring BootとJavaの互換性一覧!3.5/3.4/3.3はJava 21・17に対応してる?
No.2
Java&Spring記事人気No2
Servlet
JavaのHttpSessionを徹底解説!初心者でもわかるセッション管理の基本
No.3
Java&Spring記事人気No3
Java
JavaのIOExceptionクラス徹底解説!初心者向けファイル入出力エラー対策ガイド
No.4
Java&Spring記事人気No4
JSP
JSPの基本タグ一覧と使い方まとめ!実務で使えるタグを紹介
No.5
Java&Spring記事人気No5
Spring
Springの@Serviceアノテーションの使い方を徹底解説!初心者でもわかるSpring フレームワーク入門
No.6
Java&Spring記事人気No6
Java
Java開発環境「Eclipse(Pleiades)」のインストール方法とメリットを初心者向けに解説
No.7
Java&Spring記事人気No7
Spring
Spring BootとVS Codeで開発を始めよう!拡張機能・launch.json・ホットリロードを丁寧に解説
No.8
Java&Spring記事人気No8
Spring
Springの@Componentアノテーションの使い方を徹底解説!初心者でもわかるSpring Boot入門