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

cakePHP3 serialize&compact

Contents1 serialize2 compact serialize cakePHP3の記述で

みたいな記述をよく見かけていま …

no image

heroku+cakePHPによるメール送信

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

no image

ループ処理+switch

PHPでちょっと小ネタ foreachやwhileのようなループを抜けるときにcontinueを使うんですが、その中にswitchが入っていると、switchに対してのcontinueがきいてしまって …

no image

S3 commandPoolについて

S3のcommandPoolに関して。 S3にファイルをアップロード、ダウンロードするときに、1つ1つファイルをアップロード、ダウンロードすることが一般的かと思いますが、ファイル数が多くなるとなかなか …

no image

メールパーサー(mailparseとphp-mime-mail-parser)に関して

以前、POP3を使ったメール受信というエントリーでメールパーサーをインストールしたんですが、他のライブラリをインストールする機会があったんでメモ。 https://github.com/php-mim …