這篇文章主要介紹了關於laravel5.6與thinkphp3.2使用redis共享session的方案,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下
在實際的專案中,歷史專案使用thinkphp3.2開發,現在需要更新功能,更新功能的部分,擬使用laravel5.6進行開發。
問題描述
其中需要解決幾個關鍵問題,其中之一就是使用者認證的問題。即在系統1只登入後,系統2中自動辨識其登入資訊。即本質需要解決:laravel與thiniphp共享session的問題。
方案設計
session採用redis進行儲存。 thinkphp與laravel共離存取redis,依照相同的cookie,自動取得儲存到redis中的認證使用者資訊。
解決方案
thinkphp開啟redis支持
thinkphp3.2並不沒有整合session的redis支持,此時,我們使用php中的設定來開啟。在index.php中,我們加入以下兩行語句:
ini_set("session.save_handler", "redis"); ini_set("session.save_path", "tcp://redis:6379");
也可以將其加入到config.php設定檔中
#此時, thinkphp在進行session儲存時,將以PHPREDIS_SESSION做為前綴進行儲存。
laravel開啟redis
laravel開啟redis的方法相對來講稍微複雜一些。具體信息,需要參考官方文件使用composer來安裝Predis並進行相關配置。
laravel取得thinkphp的session
由於laravel完全棄用了PHP的內建session。所以我們是沒有辦法能過$_SESSION來取得任何資訊的(你甚至會得到一個變數未定義的錯誤)。由於laravel的cookie進行了加密處理。所以,我們也不能用laravel自備的cookie來取得cookie資訊。
具體實作的想法為:
1 取得原生cookie。
2 接拼PHPREDIS_SESSION組成key
3 使用redis直接取得key中存的值
... use Illuminate\Support\Facades\Redis; ... $cookie = $_COOKIE['PHPSESSID']; $session = Redis::get('PHPREDIS_SESSION:' . $cookie);
此$session即為thinkphp系統中的session值。
以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!
相關推薦:
#以上是laravel5.6與thinkphp3.2使用redis共享session的方案的詳細內容。更多資訊請關注PHP中文網其他相關文章!

tostartaphpsession,usesesses_start()attheScript'Sbeginning.1)placeitbeforeanyOutputtosetThesessionCookie.2)useSessionsforuserDatalikeloginstatusorshoppingcarts.3)regenerateSessiveIdStopreventFentfixationAttacks.s.4)考慮使用AttActAcks.s.s.4)

會話再生是指在用戶進行敏感操作時生成新會話ID並使舊ID失效,以防會話固定攻擊。實現步驟包括:1.檢測敏感操作,2.生成新會話ID,3.銷毀舊會話ID,4.更新用戶端會話信息。

PHP会话对应用性能有显著影响。优化方法包括:1.使用数据库存储会话数据,提升响应速度;2.减少会话数据使用,只存储必要信息;3.采用非阻塞会话处理器,提高并发能力;4.调整会话过期时间,平衡用户体验和服务器负担;5.使用持久会话,减少数据读写次数。

PHPsessionsareserver-side,whilecookiesareclient-side.1)Sessionsstoredataontheserver,aremoresecure,andhandlelargerdata.2)Cookiesstoredataontheclient,arelesssecure,andlimitedinsize.Usesessionsforsensitivedataandcookiesfornon-sensitive,client-sidedata.

phpIdentifiesauser'ssessionSessionSessionCookiesAndSessionId.1)whiwsession_start()被稱為,phpgeneratesainiquesesesessionIdStoredInacookInAcookInAcienamedInAcienamedphpsessIdontheuser'sbrowser'sbrowser.2)thisIdallowSphptpptpptpptpptpptpptpptoretoreteretrieetrieetrieetrieetrieetrieetreetrieetrieetrieetrieetremthafromtheserver。

PHP會話的安全可以通過以下措施實現:1.使用session_regenerate_id()在用戶登錄或重要操作時重新生成會話ID。 2.通過HTTPS協議加密傳輸會話ID。 3.使用session_save_path()指定安全目錄存儲會話數據,並正確設置權限。

phpsessionFilesArestoredIntheDirectorySpecifiedBysession.save_path,通常是/tmponunix-likesystemsorc:\ windows \ windows \ temponwindows.tocustomizethis:tocustomizEthis:1)useession_save_save_save_path_path()


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

Dreamweaver CS6
視覺化網頁開發工具

Dreamweaver Mac版
視覺化網頁開發工具

SublimeText3 Linux新版
SublimeText3 Linux最新版