最新在學(xué)習(xí)laravel,用到了session,因?yàn)閘aravel沒(méi)法用$_SESSION 所以只能用框架的session。
貼上代碼
?php
namespace App\Http\Controllers;
use App\Http\Requests;
use Request;
use Illuminate\Support\Facades\Session;
class CommonController extends Controller
{
static function login(){
$team_id=Request::input('team_id');
$uuid=Request::input('uuid');
$key=Request::input('key');
if(empty($team_id)){
$team_id=Session::get('team_id');
}
if(empty($uuid)){
$uuid=Session::get('uuid');
}
if(empty($key)){
$key=Session::get('key');
}
// session(['team_id'=>$team_id]);
Session::put('team_id',$team_id);
Session::put('uuid',$uuid);
Session::put('key',$key);
Session::save();
}
public static function islogin(){
$team_id=Session::get('team_id');
$uuid=Session::get('uuid');
$key=Session::get('key');
if(!empty($team_id)!empty($uuid)){
if($key != 1234){
echo "沒(méi)有權(quán)限";
exit;
}
}else{
echo "沒(méi)有權(quán)限";
exit;
}
}
}
在當(dāng)前頁(yè)面可以到SESSION,但是跨頁(yè)面就失效,以為是AJAX的CSRF驗(yàn)證問(wèn)題,查找試了不是,然后經(jīng)過(guò)打印發(fā)現(xiàn)2個(gè)SESSION不一致,繼續(xù)檢查最后發(fā)現(xiàn)是在定義路由的時(shí)候沒(méi)有定義在同一個(gè)分組內(nèi)所以導(dǎo)致SESSION不一致。
將路由重新定義好了
Route::group(['middleware'=>'web'],function() {
Route::any('/report/billviews', 'report\UserbillController@BillViews');
Route::any('/report/index','report\UseraccessController@index');//把需要用到session的路由請(qǐng)求全部放在web組里。
Route::any('/report/countprice', 'report\UserbillController@CountPrice');
Route::any('islogin', 'CommonController@islogin');
Route::any('login', 'CommonController@login');
});
還有個(gè)坑laravel5.2的session必須要過(guò)中間件
以上這篇解決laravel session失效的問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- 對(duì)laravel的session獲取與存取方法詳解
- 解決Laravel無(wú)法使用COOKIE和SESSION的問(wèn)題