gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区

站長資訊網
最全最豐富的資訊網站

踩坑分享:Laravel集成phpCAS過程

下面由Laravel教程欄目給大家分享一個Laravel 集成 phpCAS 踩坑記,希望對需要的朋友有所幫助!

Laravel 集成 phpCAS 踩坑記

CAS 是目前比較流行的單點登錄協議,官方提供了 php 版本的 client 端 phpCAS,到目前為止其編碼風格還一直停留在 PEAR 時代,連命名空間都沒有使用。好在 phpCAS 支持 composer 引入,做過幾個 Laravel 項目引入也沒有什么問題,然而這兩天有一個項目需要從單機部署變成多機部署,萬萬沒想到在這里踩了一些坑,在此記錄一下。

回調坑

在跳轉到 CAS Server 進行認證時發現,傳入的回調地址被加上了端口8080。因為是多機部署,所以訪問請求會先經過負載均衡器(阿里云 SLB),再到達 web 服務器,而這個8080是 web 服務器的監聽端口。

于是追查 phpCAS 生成回調地址的邏輯,發現有這么一段代碼:

if (empty($_SERVER['HTTP_X_FORWARDED_PORT'])) {     $server_port = $_SERVER['SERVER_PORT']; } else {     $ports = explode(',', $_SERVER['HTTP_X_FORWARDED_PORT']);     $server_port = $ports[0]; }

而阿里云的 SLB 并不會傳給后端服務器 X-FORWARDED-PORT 這個 http 頭,因此 phpCAS 就會拿到 $_SERVER['SERVER_PORT'] 也就是 nginx 的端口8080。

好在 phpCAS 提供了 setFixedServiceURL 函數,可以讓我們手動去設定回調地址:

phpCAS::setFixedServiceURL($request->url());

這下回調地址正常了,但是從 CAS Server 返回到 client 端時被告知 ticket 無效。

繼續查日志和代碼,發現這里是自己疏忽了,當 CAS Server 返回到 client 端時頁面的 url 是 http://client/login?ticket=xxxxx,而 client 端使用 ticket 向 server 換取用戶信息時還需要帶上申請該 ticket 時的回調地址(service),server 端會校驗 ticket 和 service 是否一致,而申請 ticket 時的 service 應該是 http://client/login,因此我們需要把 url 里的 ticket 參數去掉。

phpCAS::setFixedServiceURL($this->getUrlWithoutTicket($request));

getUrlWithoutTicket 函數如下:

private function getUrlWithoutTicket(Request $request) {     $query = parse_query($request->getQueryString());     unset($query['ticket']);     $question = $request->getBaseUrl().$request->getPathInfo() == '/' ? '/?' : '?';      return $query ? $request->url().$question.http_build_query($query) : $request->url(); }

Session 坑

這是一個 phpCAS + Laravel 的組合坑,坑得死去活來沒脾氣。

PHP 默認是 Session 存儲方式是文件,因此單機變多機一個很重要的點就是處理 Session 共享。方案也很簡單,就是把 Session 存儲方式從文件改成 redis/memecache/database 等。

Laravel 默認提供了這些 driver,于是興沖沖地改了下 .env 文件,把 SESSION_DRIVER 改成 redis。拉到線上一試,發現不行,phpCAS 對 $_SESSION 變量的變更并沒有被寫到 redis 里,怎么回事!

于是追了一下 Laravel 的 Session 實現,發現并不是想象中的使用 session_set_save_handler 來注冊 Session 讀寫邏輯,也就是說 Laravel 的 Session 其實并沒有修改 php 的 $_SESSION 的讀寫邏輯,直接操作 $_SESSION 還是走的默認行為(讀寫本地文件)。

那好吧,好在 Laravel 的幾個 SessionDriver 都實現了 SessionHandlerInterface 接口,我們可以自己調用一下 session_set_save_handler

session_set_save_handler(app(StartSession::class)->getSession($request)->getHandler());

萬萬沒想到報錯!

session_write_close(): Session callback expects true/false return value

追了一下 Laravel 的代碼,發現 redis driver 的父類 IlluminateSessionCacheBasedSessionHandlerwrite 方法返回的是 void。于是提了一個 PR 打算修一下,沒想到被拒絕,原來是之前有人修過又被 revert 了,說是會導致服務器卡住,然而我并沒有找到具體的 issue。

那好吧,memcache 和 redis 都是繼承的這個父類,那我就換只好 database 試試看。

這回 session_write_close 不報錯了,但是 CAS 登錄還是有問題,不斷在 CAS server 和回調 url 之間跳轉。于是又追了一路 log 和代碼,發現 database driver 類 IlluminateSessionDatabaseSessionHandlerdestroy 方法在銷毀 Session 之后沒有將 $this->exists 屬性標記為 false,而 phpCAS 有一處邏輯是 renameSession

$old_session = $_SESSION; session_destroy(); $session_id = preg_replace('/[^a-zA-Z0-9-]/', '', $ticket); session_id($session_id); session_start(); $_SESSION = $old_session;

后果就是 $_SESSION = $old_session; 所對應操作 session 表的 sql 執行的是 update 而不是 insert,也就是沒能將 session 數據寫入 session 表!

實在沒有辦法了,只能自己寫一個 Session Wrapper 來處理。

從上面兩個情況來看,redis driver 比較好處理,只要能在調用 write 方法時返回 true 就可以了。所以代碼如下

namespace AppServices;  use SessionHandlerInterface;  class MySession implements SessionHandlerInterface {     /**      * @var SessionHandlerInterface      */     protected $realHdl;      /**      * Session constructor.      * @param SessionHandlerInterface $realHdl      */     public function __construct(SessionHandlerInterface $realHdl)     {         $this->realHdl = $realHdl;     }      public function close()     {         return $this->realHdl->close();     }      public function destroy($session_id)     {         return $this->realHdl->destroy($session_id);     }      public function gc($maxlifetime)     {         return $this->realHdl->gc($maxlifetime);     }      public function open($save_path, $name)     {         return $this->realHdl->open($save_path, $name);     }      public function read($session_id)     {         return $this->realHdl->read($session_id) ?: '';     }      public function write($session_id, $session_data)     {         $this->realHdl->write($session_id, $session_data);          return true; // 這里     } }

然后調用 session_set_save_handler 變成

session_set_save_handler(new MySession(app(StartSession::class)->getSession($request)->getHandler()));

Done !

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
国产片侵犯亲女视频播放| 亚洲国产精品久久久久爰色欲| 日本欧美视频在线观看| 久久av秘一区二区三区| 久久久久久久久久一区| 亚洲老女人av| 一级黄色在线播放| 国产又粗又大又爽的视频| 黄色a级在线观看| 亚洲精品天堂成人片av在线播放| 免费成人黄色大片| 免费观看中文字幕| 日韩一级性生活片| 国产 福利 在线| 九色porny91| 亚洲一级片免费观看| 自拍一级黄色片| www.射射射| 日韩精品你懂的| 日韩欧美视频免费在线观看| 日本www在线视频| 91插插插插插插插插| 日韩视频在线观看视频| 99在线免费视频观看| 一区二区三区 欧美| 日本xxx免费| 国产高清精品在线观看| www.污网站| 免费无遮挡无码永久视频| 天天干天天草天天| 亚洲人成无码网站久久99热国产 | 成熟老妇女视频| 亚洲第一色av| 国产又大又硬又粗| 超薄肉色丝袜足j调教99| 欧美成人免费高清视频| 日韩欧美中文视频| 亚洲第一狼人区| 成年人午夜视频在线观看 | 4444亚洲人成无码网在线观看| 91av俱乐部| 成年人网站免费视频| 天天做天天爱天天高潮| 亚洲欧美另类动漫| 久久综合色视频| 男人添女荫道口喷水视频| 午夜精品在线免费观看| 欧美精品久久久久久久自慰| 日韩视频在线观看视频| 国内外成人免费在线视频| 99精品免费在线观看| 黄色国产一级视频| 无码粉嫩虎白一线天在线观看| 做a视频在线观看| 久久婷五月综合| 国产精品久久久久9999小说| 欧美爱爱视频免费看| 分分操这里只有精品| 欧美精品久久久久久久自慰| 99久久免费观看| www.日本三级| 丝袜人妻一区二区三区| 欧美日韩不卡在线视频| 国产又粗又大又爽的视频| 亚洲黄色网址在线观看| 美女av免费观看| 久久国产午夜精品理论片最新版本| 一本色道久久88亚洲精品综合 | 亚洲怡红院在线| 想看黄色一级片| 国产高潮呻吟久久久| 欧洲金发美女大战黑人| 国产高清不卡无码视频| 欧美国产日韩激情| 亚洲爆乳无码专区| 亚洲无在线观看| 国产人妻人伦精品| a在线视频观看| 中文字幕第80页| 99中文字幕在线观看| www.日本在线视频| 777久久久精品一区二区三区| 大肉大捧一进一出好爽动态图| 国产天堂在线播放| 美国av在线播放| 99999精品视频| 免费成人深夜夜行网站视频| 欧美一级片免费播放| 亚洲成色www.777999| 99热这里只有精品免费| 久草青青在线观看| 黄色免费高清视频| 免费国产成人av| 最近免费观看高清韩国日本大全| 欧美黄网在线观看| 潘金莲激情呻吟欲求不满视频| 成人在线免费高清视频| www.99在线| 日韩国产一级片| 中文字幕国内自拍| 欧美综合在线播放| 亚洲小视频在线播放| 久久综合伊人77777麻豆最新章节| 四虎1515hh.com| 邪恶网站在线观看| 欧美精品久久久久久久自慰| 日韩高清在线一区二区| 国产精彩免费视频| 国产免费黄色av| 天天做天天躁天天躁| 污污网站免费观看| 久久综合久久色| 激情深爱综合网| 日韩一级特黄毛片| 91 视频免费观看| 91插插插插插插插插| 日韩免费毛片视频| 女性女同性aⅴ免费观女性恋| 成年人视频大全| 老司机av福利| 熟女熟妇伦久久影院毛片一区二区| 欧美 国产 日本| 九九九九免费视频| 欧美精品一区二区三区三州| 337p亚洲精品色噜噜狠狠p| 久久天天东北熟女毛茸茸| 91福利免费观看| 国产精品美女在线播放| 亚洲高清av一区二区三区| 中文字幕中文在线| xxxx在线免费观看| www亚洲国产| 成年人深夜视频| 欧洲精品一区二区三区久久| 欧美中文字幕在线观看视频 | 999这里有精品| 亚洲一级片免费观看| 久久人人爽人人片| 日韩欧美精品免费| 久草热视频在线观看| 亚洲乱码中文字幕久久孕妇黑人| 69堂免费视频| 欧美日韩中文不卡| 大地资源第二页在线观看高清版| 天天综合五月天| 久久综合久久网| 日本888xxxx| 污视频在线观看免费网站| 少妇一晚三次一区二区三区| 日韩精品xxxx| 日本一二三区在线| 妞干网在线视频观看| 久久九九国产视频| 欧美一级特黄aaa| 国产二级片在线观看| 天天爽夜夜爽一区二区三区| 欧美a级黄色大片| 国产高清精品在线观看| 亚洲18在线看污www麻豆| 奇米777四色影视在线看| 欧美国产亚洲一区| 最近中文字幕免费mv| 国产亚洲精品网站| 在线视频一二三区| 国产一级特黄a大片免费| 国产三级中文字幕| 久久久久久久久久久久91| 国产在线xxxx| 国产在线观看中文字幕| 欧美亚洲一二三区| 欧美大黑帍在线播放| 天天干天天爽天天射| 久久久亚洲精品无码| 日韩视频在线免费播放| 欧美精品久久久久久久久25p| 91午夜在线观看| 91xxx视频| 中文 日韩 欧美| 蜜桃免费在线视频| 苍井空浴缸大战猛男120分钟| 日本免费黄色小视频 | 99色这里只有精品| 大地资源第二页在线观看高清版| 日韩中文字幕组| 国产黄页在线观看| 精品久久久久久久久久中文字幕| 色中文字幕在线观看| 亚洲欧美日本一区二区| 欧美日韩在线观看不卡| 北条麻妃视频在线| 国产极品美女高潮无套久久久 | 一本色道久久亚洲综合精品蜜桃| 俄罗斯av网站| 欧美激情视频免费看| 黄网站欧美内射| 国自产拍偷拍精品啪啪一区二区| 国产激情片在线观看| 999一区二区三区| 人妻少妇精品无码专区二区| 欧美成人精品免费|