php - TP5的登錄驗證問題
問題描述
應該屬于比較菜的一個問題,就是我在處理前后端的時候,需要判斷是否存在session來確定用戶是否登錄。
但是我通過文檔看到的辦法只能自己在每個頁面都引入一次判斷,然后進行其他操作,不過肯定有更簡單的辦法來處理這個事,自己實在是研究不出來了,請大神幫忙!
主要就是如何能一次設置,然后讓制定目錄下的頁面都判斷是否登錄,從而方便下一步的操作
問題解答
回答1:第一種引用訪問:將所有session判斷驗證寫在一個類裡面。在每一個控制器裡創建前置控制器方法或者初始化控制,在方法裡面直接引用session類的登錄驗證方法。第二種繼承:就是每個控制器都繼承session驗證類,這樣每次訪問控制器都繼承session所有類與方法,在session類設置初始化控制,作為session的登錄驗證
個人推薦第二種,因為不需要在每個控制器裡面初始化控制器,減少代碼便於維護
回答2:寫一個基類如Base.php,通過其_initialize來實現,如:
<?phpnamespace appadmincontroller;use thinkController;class Base extends Controller{ public function _initialize(){$uid = session(’uid’);if($uid == null){ $this->rediect(’Login/index’,’請先登錄后操作’);} }}
其中Login.php不能繼承Base.php,否則需要另外的特殊判斷,如:
<?phpnamespace appadmincontroller;use thinkController;class Login extends Controller{ public function _initialize(){$uid = session(’uid’);if($uid != null){ $this->rediect(’Index/index’,’已登錄’);} }}回答3:
我也是小白一枚,只是有個想法,可以在登錄存儲session之后,在后端寫一個判斷session的公共方法,然后在需要目錄下面嗲用這個方法,這樣就不需要在每個目錄下面都去判斷了!
只是個人想法,沒有實踐??!回答4:
寫一個驗證中間件(行為),然后在路由里調用,可以任意指定哪些頁面需要調用這個驗證的中間件.
可以看下手冊里行為那一部分
回答5:不用每個頁面引入判斷啊,你把所有的控制器繼承一個公共的控制器,在公共的控制器寫一次session判斷就可以了
相關文章:
1. 致命錯誤: Class ’appfacadeTest’ not found2. docker-compose中volumes的問題3. python - 數據無法插入到mysql表里4. dockerfile - 為什么docker容器啟動不了?5. javascript - 求正則表達式的寫法6. javascript - 小程序跳轉失敗?7. java - Oracle如何獲取去重結果集中某一條數據的下一條數據8. css - 關于偽類背景問題9. 老師,請問我打開browsersync出現這個問題怎么解決???10. mysql scripts提示 /usr/bin/perl: bad interpreter
