Laravel无法检索POST请求中保存的会话数据

时间:2016-11-21 04:15:24

标签: php laravel session post get

我遇到了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');

这里的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'
   ]);

 }

现在问题是如果请求访问其他get请求部分中的会话值,那么它就不允许访问。

public function dashboard(Request $request)
{

   $data = $request->session()->all();

   print_r($data);

   return view('welcome', ['name' => 'James']);
}

这里没有显示已保存的会话数据,因为它是GET请求。

现在如果尝试使用POST请求在任何其他方法中获取请求,它将在doLogin方法中显示已保存的数据

//it's a POST requset
public function test(Request $request)
{
   $data = $request->session()->all();
   print_r($data);
}

如何在GET请求的方法中访问会话数据?

先谢谢,

更新

请注意,在verifyCsrfToken middelwere的excepts区域添加网址“'/ 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'
   ];
} 

2 个答案:

答案 0 :(得分: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";
    }

并在test函数中

return $request->session()->get('userId');

答案 1 :(得分:0)

您为什么要尝试手动验证用户身份?

对于会话操作使用"会话"门面。

例如:

Session::set('your_session_key', 'Session Value');
Session::save();
$yourSessionKey = Session::get('your_session_key');