skillup

技術ブログ

PHP

Laravelでのアプリ間のログイン連携

投稿日:

実務でLaravelで複数のアプリを作成し、アプリ同士でログイン連携をさせるという機能が実務であったため、メモします。

例えばhttp://example.comという売上管理のアプリでログイン認証をしており、ログイン後、http://customer.examle.comにもそのログイン状態が引き継ぎたいという状態です。

例えば顧客管理のアプリを別管理していて、売上管理アプリの内部からリンクで繋げたい場合などがそうです。

どちらかというとメインとなるアプリがあり(この場合でいうと売上管理)、そこでログインした後、サブのアプリ(この場合、顧客管理)にもログインを引き継ぐというケースが多いかと思います。

やるべきこと

sessionはdatabase

当たり前ですが、sessionはDBでないと引き継げないのでDBにしましょう。

具体的には.envで

と設定してあげれば大丈夫です。

APP_KEYを同一にする

内部はブラックボックス化されており、どういう連携を取っているかはわかりませんが、ログイン連携をするにはLaravelのAPP_KEYを同一にする必要があります。

私が試したケースではメインのAPP_KEYにサブのAPP_KEYを書き換えて合わせました。(*メインは通常のphp artisan key:generateで生成)

SESSION_DOMAIN

サブのアプリはサブドメインで運用していますので、ドメイン間でクッキーを共通化できるようにしておきましょう。

おそらくドメインが共通でないと無理かと思います。

今回のドメインの例だとサブのアプリの.envに

SESSION_DOMAIN=example.com

と設定してあげればOKです。

認証テーブルはconnectionを切り替えて設定

Laravelではconnectionを切り替えることで複数のデータベース間に接続をすることができますので、認証で使うモデルにメインのアプリのconnecitonを設定してあげればOKです。

.env

User.php(例えばこのモデルを認証で使う場合)

注意点

Laravelのバージョンにより認証方法のロジックが変わるようで、2つのアプリのバージョンに注意しましょう。

メイン 5.4.36

サブ 5.5.41

はOKだったのですが、サブを5.5.44にあげたら認証ロジックが変わったようでunserialize(): Error at offset 0 of 40 bytesなるエラーが発生してログイン連携ができませんでした。

 

-PHP
-

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

no image

PHPでの日付関数の扱い方

このブログの投稿数ももう少しで150近くになりました。 で、9割以上がJavaなんですが、私はPHPのスクールを運営しています(笑) ということでPHPのスキルを忘れてはいけないということで、今日はち …

no image

アプリケーションアーキテクチャについて 〜ドメインモデルに関して〜

前回のトランザクションスクリプトパターンの反省から 今回はいわゆるドメインモデルの具体例に関して。 ドメイン駆動型設計には以下のような特徴があります。 大きく、アプリケーションの構成を以下のように分け …

no image

phpの時分秒+cakePHPのupdate

ちょっと小ネタ集になります。 Contents1 PHPで秒→時分秒変換2 cakePHPでのupdate PHPで秒→時分秒変換 PHPで秒数から時分秒に変換するプログラムです。 汎用的かなと思った …

no image

call_user_funcについて

call_user_funcについて。 call_user_funcはメソッドを動的に呼ぶことができるメソッドの1つで、コールバック関数を使いたいときに使われます。JavaScriptでは比較的多いと …

no image

heroku+cakePHPによるメール送信

herokuに作ったアプリでメール送信機能を実装したのでその時のメモを。 まずメール送信自体はmb_send_mailなどではなく、SendGridというアプリを使います。 使い方ですが、heroku …