ITパスポート講座

SAML認証の仕組みを図解で解説【初心者向けにSMAL認証の流れを詳しく説明します!】

こんにちは、インフラエンジニアのryuです。

今回は、SAML認証の仕組みを図解で解説します。SAMLとは、認証や認可の情報を違うドメイン間で安全にやり取りする規格です。シングルサインオン(SSO)を実現する仕組みです。SAML認証の仕組みを図解を用いて、初心者の方に分るように解説します。

サーバー構築を実践で身につけるInfraAcademy

※本ページには、プロモーション・アフィリエイトリンクが含まれています

SAML認証の仕組みを解説

SAML認証って何・・・?

SAMLとは、認証や認可の情報を違うドメイン間で安全にやり取りする規格です。

SAML認証の仕組みは以下の通りです。

  1. ブラウザからサービスにアクセス
  2. 利用者はユーザ情報を入力
  3. IDPは認証応答をブラウザ経由でSPに送信
  4. SPはサービスの提供を開始する

IDPやSPなど見慣れない用語がありますが、あとで解説します。

では、SAML認証の仕組みを詳しく解説します!

SAML認証の仕組みを理解するための用語解説

SAML認証の仕組みを理解するために2つの用語を覚えましょう。

  1. SP・・・Service Provider
  2. IDP・・・ID Provider

SPとは、サービスプロバイダーの略で、サービスの提供をするサーバーです。

IDPとはIDプロバイダーの略で、クライアントの認証を行います。

SAML認証を理解するには、SPとIDPの2つは覚えておきましょう。

SAML認証の流れを理解しよう!

ここからは、SAML認証の流れについて解説します。SAML認証はこちらの手順で進みます。

  • ブラウザからサービスにアクセス
  • 利用者はユーザ情報を入力
  • IDPは認証応答をブラウザ経由でSPに送信
  • SPはサービスの提供を行う

では、SAMLの流れについて詳しく見ていきましょう。

ブラウザからサービスにアクセス

ここから、SAML認証の仕組みを解説します。

まず、ブラウザーからサービスにアクセスします。

例として、Office365で解説します。

まず、Office365を起動します。Excelでブックを作成しようとすると、Microsoftの認証画面が表示されます

samlログイン画面

ここまでの流れを図にすると以下のようになります。

SAML認証の仕組み

まず、サービス(Excel)を使いたい!と要求を出します。そうすると、SPはIDPのサーバーで認証してね!とリダイレクト指示を出します。リダイレクトの指示を受けたブラウザーは、IDPにアクセスします。そして、IDPは応答を返し、ブラウザーに認証画面が表示されます。

利用者はユーザ情報を入力

次に、利用者はユーザ情報を入力します。

普通のログインと同じ動作です。ユーザ名とパスワードの入力を行います。

ここの説明は簡単なのでこれくらいにします。

先ほどの例では、Microsoftのアカウントで認証を行います。アカウント情報はIDPに保存されています。

IDPは認証応答をブラウザ経由でSPに送信

ユーザ名とパスワードの入力が完了すると、IDPは認証アサーションをブラウザ経由でSPに送信します。

認証アサーションとは、ユーザの情報をXML形式で記述したものです。

ここまでの動作は以下のようになります。

SAML認証応答

SPはサービスの提供を開始する

最後に、認証アサーションを受け取ったSPは、認証アサーションを検証します。検証に成功したら、SPはサービスの提供を開始します。

これで、クライアントはサービスを使えるようになります。

先ほどの例では、MicrosoftアカウントでログインしてからExcelが利用できるようになります。

SAML認証仕組みまとめ

最後にまとめです。

Office365でExcelを利用することで説明します。

  1. ブラウザからサービスにアクセス・・・Office365でExcelを利用
  2. 利用者はユーザ情報を入力・・・Microsoftアカウントを入力
  3. IDPは認証応答をブラウザ経由でSPに送信
  4. SPはサービスの提供を開始する・・・Excelが使える

③の部分では、AzureActiveDirectoryの動作があるので、詳細の説明は省略します。

簡単に説明すると、Micorosoftのアカウント情報を持っているデータベースで認証処理をしています。

これでSAML認証の仕組みの説明を終わります。

SAML認証はシングルサインオンを行うために必要な技術です。シングルサインオンを実装するためには、仕組みを理解しておく必要があるので、ぜひ覚えましょう。

その他のインフラやセキュリティに関する知識については、こちらで解説しています。

さらにセキュリティを勉強したい方は、こちらの参考書がオススメです。

ABOUT ME
ryu@InfraAcademyというインフラ学習サービス運営
大手企業→上場ベンチャー→スタートアップでエンジニアをしていました。 インフラエンジニア歴10年以上。 Linuxやネットワークの学習ができるサービスInfraAcademyを運営中。
RELATED POST