Dbb*_*Dbb 6 php laravel vue.js axios
我在vue.js中有一个登录表单。我只需要使用vue.js和laravel登录用户。登录后,用户将重定向到仅使用laravel开发的仪表板。我正在尝试登录,但无法正常工作,并auth()->guard返回null,以便用户重定向到登录页面而非仪表板。在这种情况下,当我使用邮递员时,效果很好。
Vue js
this.$http.post('http://localhost/project/admin/vendors/validate_login',{phone_number : this.phone_number},{
headers: {
"Access-Control-Allow-Origin": "*"
}
})
.then((response) =>{
if(response.data.status == 'success')
{
window.location = "http://localhost/project/admin/vendors/dashboard";
}
})
Run Code Online (Sandbox Code Playgroud)
Laravel-验证登录名:
public function validate_login(Request $request)
{
$arr_rules = array();
$status = false;
$remember_me = "";
$arr_rules['phone_number'] = "required";
$validator = validator::make($request->all(),$arr_rules);
if($validator->fails())
{
return response()->json([
'status' => 'error',
'msg' => "Mobile number is empty"
]);
}
$obj_group_vendor = $this->UsersModel
->where('phone_number',$request->only('phone_number'))
->first();
if($obj_group_vendor)
{
if($this->auth->attempt(['phone_number' => $request->phone_number,
'role_id' => 3]))
{
return response()->json([
'status' => 'success',
'msg' => "You are successfully login to your account."
]);
}
else
{
return response()->json([
'status' => 'error',
'msg' => "Invalid login credential."
]);
}
}
else
{
return response()->json([
'status' => 'error',
'msg' => "Invalid login credentials."
]);
}
return;
}
Run Code Online (Sandbox Code Playgroud)
路线:
$web_vendor_path = config('app.project.vendor_panel_slug');
Route::group(array('prefix' => $web_vendor_path,
'middleware'=> ['vendor_auth_check']), function ()
{
$route_slug = 'vendor_';
Route::post('validate_login', ['as' => $route_slug.'validate',
'uses' => $module_controller.'validate_login']);
});
Route::group(array('prefix' => $web_vendor_path,
'middleware'=>'auth_vendor'), function ()
use($web_vendor_path)
{
$route_slug = 'vendor_';
$module_controller = "Vendor\DashboardController@";
Route::get('/dashboard',['as' => $route_slug.'index',
'uses' => $module_controller.'index']);
});
Run Code Online (Sandbox Code Playgroud)
任何帮助,将不胜感激。
从浏览器执行 POST/PATCH/PUT/DELETE 请求时,您需要包含页面的 CSRF 令牌。
this.$http.post('http://localhost/project/admin/vendors/validate_login',{phone_number : this.phone_number},{
headers: {
"Access-Control-Allow-Origin": "*",
"X-CSRF-TOKEN": document.head.querySelector('meta[name="csrf-token"]').content
}
})
.then((response) =>{
if(response.data.status == 'success')
{
window.location = "http://localhost/project/admin/vendors/dashboard";
}
})
Run Code Online (Sandbox Code Playgroud)
并确保您将 CSRF 作为元标记包含在所有页面中:
<meta name="csrf-token" content="{{ csrf_token() }}">
Run Code Online (Sandbox Code Playgroud)