カテゴリ: Rails 更新日: 2026/02/16

Rails認可入門|Pundit導入と基本をやさしく解説(policy作成・authorize・verify_authorized)

Pundit導入と基本:policy作成・authorize/verify_authorizedの使い方
Pundit導入と基本:policy作成・authorize/verify_authorizedの使い方

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

生徒

「Railsで、使っていい人とダメな人を分ける仕組みってありますか?」

先生

「あります。Railsでは“認可”と呼ばれていて、Punditというライブラリがよく使われます。」

生徒

「ログインとは違うんですか?」

先生

「ログインは本人確認、認可は“その人がその操作をしていいか”を判断する仕組みです。」

1. Railsにおける認可とは?

1. Railsにおける認可とは?
1. Railsにおける認可とは?

Railsの認可(Authorization)とは、「このユーザーは、この操作をしても良いか」を判断する仕組みです。例えば、ブログの記事を読むだけの人編集できる人を分けたい場合に使います。

よく似た言葉に認証(Authentication)がありますが、こちらは「誰か」を確認する仕組みです。ログイン画面でIDとパスワードを入力するのが認証、ログイン後に何ができるか決めるのが認可です。

Punditは、Railsで認可をシンプルに書くための定番ライブラリで、ポリシー(policy)というクラスを使って判断ルールをまとめます。

2. Punditとは何か?初心者向けに説明

2. Punditとは何か?初心者向けに説明
2. Punditとは何か?初心者向けに説明

Punditは「この人はOK?NG?」を判断するルールブックのようなものです。ルールはPolicyクラスに書きます。

たとえば「自分が書いた記事だけ編集できる」というルールがあるとします。この判断をコントローラに直接書くと、コードがごちゃごちゃします。Punditを使うと、判断を別の場所にまとめられます。

Rails・認可・Pundit・ポリシー設計というキーワードは、Rails学習で必ず出てくる重要ポイントです。

3. Punditのインストールと初期設定

3. Punditのインストールと初期設定
3. Punditのインストールと初期設定

まずはPunditをRailsアプリに追加します。GemfileにPunditを追加して、インストールします。


gem 'pundit'

次に、コマンドを実行します。


bundle install

ApplicationControllerにPunditを読み込みます。


class ApplicationController < ActionController::Base
  include Pundit
end

これでRailsアプリ全体でPunditが使える状態になります。

4. policyファイルの作成と基本構造

4. policyファイルの作成と基本構造
4. policyファイルの作成と基本構造

Punditでは、モデルごとに〇〇Policyというクラスを作ります。たとえばArticleモデルならArticlePolicyです。

ファイルはapp/policiesフォルダに作ります。


class ArticlePolicy
  attr_reader :user, :article

  def initialize(user, article)
    @user = user
    @article = article
  end

  def update?
    user == article.user
  end
end

ここでは「ログイン中のユーザーが、記事の持ち主なら更新OK」というルールを書いています。update?のように、アクション名+?でメソッドを作るのが特徴です。

5. authorizeメソッドの使い方

5. authorizeメソッドの使い方
5. authorizeメソッドの使い方

次に、コントローラでauthorizeを使います。これは「この操作、許可されてる?」とPunditに聞く命令です。


def update
  @article = Article.find(params[:id])
  authorize @article
  @article.update(article_params)
end

この1行で、ArticlePolicyのupdate?が自動的に呼ばれます。もしNGなら、エラーが発生して処理が止まります。

初心者の方は「authorizeはチェック係」と覚えると理解しやすいです。

6. verify_authorizedで書き忘れを防ぐ

6. verify_authorizedで書き忘れを防ぐ
6. verify_authorizedで書き忘れを防ぐ

verify_authorizedは、「ちゃんとauthorizeを書いた?」を確認する仕組みです。書き忘れを防ぐ安全装置のようなものです。


class ApplicationController < ActionController::Base
  include Pundit
  after_action :verify_authorized
end

これを設定すると、authorizeを書いていないアクションがあるとエラーになります。Rails・Pundit・セキュリティを意識する上で、とても大切な考え方です。

7. 初心者がつまずきやすいポイント

7. 初心者がつまずきやすいポイント
7. 初心者がつまずきやすいポイント

Pundit初心者がよく混乱するのが、「どこに何を書くか」です。判断ルールはpolicy、実行するのはcontroller、と役割を分けるのが基本です。

また、policyのメソッド名とcontrollerのアクション名が対応している点も重要です。updateならupdate?、showならshow?という形になります。

Rails認可・Pundit導入・policy設計を理解すると、アプリの安全性が一気に高まります。

8. 認可を使うメリットと考え方

8. 認可を使うメリットと考え方
8. 認可を使うメリットと考え方

認可をしっかり書くことで、「見てはいけない情報を守る」「操作ミスを防ぐ」などの効果があります。特にRailsアプリでは、認可を書かないと誰でも操作できてしまう危険があります。

Punditはシンプルで読みやすく、初心者でも理解しやすいのが特徴です。Rails・認可・Pundit・authorize・verify_authorizedというキーワードは、実務でも頻繁に使われます。

カテゴリの一覧へ
新着記事
New1
Ruby
“すべてはオブジェクト”を体感!初心者向けRubyのオブジェクト指向入門【irbで学ぶ】
New2
Ruby
Rubyの標準入出力を完全ガイド!puts・print・pの違いとデバッグ活用法
New3
Ruby
Gemとは?RubyGemsとBundlerを初心者向けに完全解説!依存関係管理も図解でわかりやすく理解
New4
Ruby
Rubyの文字エンコーディング入門!UTF-8・マジックコメント・外部/内部エンコーディングを完全解説
人気記事
No.1
Java&Spring記事人気No1
Ruby
Rubyのreduceとinject入門!合計計算や集計を初心者向けに分かりやすく解説
No.2
Java&Spring記事人気No2
Ruby
Rubyの文字列エンコーディング完全ガイド!Encoding・force_encoding・encodeを初心者向け解説
No.3
Java&Spring記事人気No3
Ruby
Rubyの始め方ガイド:インストールから最初のHello Worldまで(Windows/Mac/Linux)
No.4
Java&Spring記事人気No4
データベース
PostgreSQLのWHERE句を徹底解説!初心者でもわかるSQLデータ抽出の基本
No.5
Java&Spring記事人気No5
Ruby
Rubyのfind/detect/find_indexを徹底解説!目的のデータを素早く探す方法
No.6
Java&Spring記事人気No6
Ruby
Rubyで比較演算子を完全解説!==・===・<=>・eql? の使い分け
No.7
Java&Spring記事人気No7
Ruby
Rubyのselect/reject/filterの使い方を完全解説!初心者向けの条件抽出レシピ
No.8
Java&Spring記事人気No8
データベース
PostgreSQLで順位付け!ROW_NUMBER関数の使い方を初心者向けに徹底解説