所以我遇到一个问题,在用户通过向数据库提交详细信息后注册后,我似乎无法将其重定向到仪表板。相反,我在firefox中收到此消息:"由于不活动,页面已过期。请刷新并重试。"并且在网址中它没有说/仪表板说/注册。
这是我的web.php路线
Route::get('/', function () {
return view('user/usersignup');
});
Route::post('/signup', [
'uses' => 'UserController@postSignUp',
'as' => 'signup'
]);
Route::post('/signin', [
'uses' => 'UserController@postSignIn',
'as' => 'signin'
]);
Route::get('/dashboard', [
'uses' => 'UserController@getDashboard',
'as' => 'dashboard'
]);
这是UserController,我的控制器。
<?php
namespace App\Http\Controllers;
use App\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
class UserController extends Controller
{
public function getDashboard(){
return view('dashboard');
}
public function postSignUp(Request $request){
$first_name = $request['first_name'];
$email = $request['email'];
$password = bcrypt($request['password']);
$user= new User();
$user->first_name = $first_name;
$user->email = $email;
$user->password = $password;
$user->save();
return redirect()->route('dashboard');
}
}
这是我的注册视图:usersignup.blade.php
<form action="{{ route('signup') }}" method="post" id="userform">
<div class="form-group">
<label for="first_name">Your first Name</label>
<input class="form-control" type="text" name="first_name" id="fullname">
</div>
<div class="form-group">
<label for="email">Your E-Mail</label>
<input class="form-control" type="text" name="email" id="email">
</div>
<div class="form-group">
<label for="password">Your Password</label>
<input class="form-control" type="password" name="password" id="password">
</div>
<button type="submit" class="btn btn-primary">Submit</button>
<input type="hidden" name="_token" value="{{ Session::token() }}">
</form>
答案 0 :(得分:2)
您使用的是CSRF错误。
在{{ csrf_field() }}
标记内使用<form>
并删除隐藏的元素name="_token"
<form action="{{ route('signup') }}" method="post" id="userform">
{{ csrf_field() }}
.....
.....
<button type="submit" class="btn btn-primary">Submit</button>
</form>
或者将隐藏元素_token
的值替换为csrf_token()
<form action="{{ route('signup') }}" method="post" id="userform">
.....
.....
<button type="submit" class="btn btn-primary">Submit</button>
<input type="hidden" name="_token" value="{{ csrf_token() }}">
</form>
答案 1 :(得分:1)
在表单中添加csrf字段而不是隐藏的_token输入:
actionSearch