我是 Laravel 的新手,所以我开始学习 Laracast 的课程,然后上课的人去验证用户并猜测等。寄存器工作正常,它使用散列密码进入数据库,它让那个用户知道刚刚注册登录(并且可以做登录用户应该在网站上做的所有事情)。当我转到我的登录表单并尝试登录时,它不会重定向并给出错误。即使用户/密码凭据不正确,它也会重新加载。
需要注册它如何将用户保存到数据库中。
$user = User::create([
'name' => request('name'),
'email' => request('email'),
'password' => bcrypt(request('password'))
]);
登录表格...
<form method="POST" action="/login">
{{ csrf_field() }}
<div class="form-group">
<label for="Email">Email:</label>
<input type="email" class="form-control" id="Email" name="Email" required>
</div>
<div class="form-group">
<label for="password">Password:</label>
<input type="password" class="form-control" id="password" name="password" required>
</div>
<div class="form-group">
<button type="submit" class="btn btn-primary">Sign in</button>
</div>
@include ('layouts.errors')
</form>
用于路由的 web.php
Route::get('/', 'PostsController@index')->name('home');
Route::get('/posts/create', 'PostsController@create');
Route::post('/posts', 'PostsController@store');
Route::get('/posts/{post}', 'PostsController@show');
Route::post('/posts/{post}/comments', 'CommentsController@store');
Route::get('/register', 'RegistrationController@create');
Route::post('/register', 'RegistrationController@store');
Route::get('/login', 'SessionsController@create')->name('login');
Route::post('/login', 'SessionsController@store');
Route::get('/logout', 'SessionsController@destroy');
处理登录的控制器
<?php
class SessionsController extends Controller
{
public function __construct()
{
$this->middleware('guest');
}
public function create()
{
return view('sessions.create');
}
public function store()
{
// Attempt to authenticate the user.
if (!auth()->attempt(request(['email', 'password']))) {
return back();
}
// Redirect them to the homepage
return redirect()->home();
}
public function destroy()
{
auth()->logout();
return redirect()->home();
}
}
错误.php
<div class="form-group">
<div class="alert alert-errors">
<ul>
@foreach($errors->all() as $error)
<li> {{ $error }} </li>
@endforeach
</ul>
</div>
</div>