FRa*_*bbi 5 php session post get laravel
我在创建和读取 Laravel 会话时遇到问题。我可以创建会话值,但问题是访问数据。如果我在 POST 请求中创建了一个会话值,那么我将无法在 GET 请求中访问它。
这是我的路线
Route::get('/', 'HomeController@index');
Route::get('/admin/dashboard', 'AdminController@dashBoard');
Route::post('/admin/login_admin', 'AdminController@doLogin');
Route::post('/admin/login_test', 'AdminController@test');
Route::get('/admin/login', 'AdminController@seeLogin');
Run Code Online (Sandbox Code Playgroud)
这里 doLogin 使用 post 方法:
public function doLogin(Request $request){
$email = $request->input("email");
$password = $request->input("password");
$checkerInfo = AdminGetLoginChecker($email, $password);
//if logged in
if($checkerInfo){
$request->session()->put('loggedIn', '1');
$request->session()->put('userId', $checkerInfo);
$request->session()->save();
return response()->json([
'success' => true,
'message' => 'logged In'
]);
}
return response()->json([
'success' => false,
'message' => 'Incorrect User Email, Password'
]);
}
Run Code Online (Sandbox Code Playgroud)
现在的问题是,如果请求访问其他获取请求部分中的会话值,则不允许访问。
public function dashboard(Request $request)
{
$data = $request->session()->all();
print_r($data);
return view('welcome', ['name' => 'James']);
}
Run Code Online (Sandbox Code Playgroud)
这里没有显示保存的会话数据,因为它是一个 GET 请求。
现在,如果尝试使用 POST 请求以任何其他方法获取请求,它将在 doLogin 方法中更早地显示保存的数据
//it's a POST requset
public function test(Request $request)
{
$data = $request->session()->all();
print_r($data);
}
Run Code Online (Sandbox Code Playgroud)
如何在 GET 请求的方法中访问会话数据?
提前致谢,
更新:
请注意在verifyCsrfToken middelwere的excepts区域添加url“'/admin/login_admin'”以避免发布数据时出现csrf令牌问题
namespace App\Http\Middleware;
use Illuminate\Foundation\Http\Middleware\VerifyCsrfToken as BaseVerifier;
class VerifyCsrfToken extends BaseVerifier
{
/**
* The URIs that should be excluded from CSRF verification.
*
* @var array
*/
protected $except = [
//
'url' => '/admin/login_admin'
];
}
Run Code Online (Sandbox Code Playgroud)
小智 0
让我们试试这样
$input = $request->all();
// imagine you have Admin.php model
$query = Admin::login($input['email'], $input['password'])->first();
if ($query)
{
Session::put('userId', $query->id);
Session::save();
return "u're in";
}
else{
return "User name or password is wrong";
}
Run Code Online (Sandbox Code Playgroud)
在你的test函数中
return $request->session()->get('userId');
Run Code Online (Sandbox Code Playgroud)