поэтому я делаю этот универсальный проект в Laravel 5.7, и я хотел добавить аутентификацию, я установил готовое решение для аутентификации Laravel, используя эту команду
php artisan make:auth
Но я заметил, что он использует электронную почту вместо имени пользователя, в контексте моего проекта электронная почта даже не является одним из атрибутов пользователя, поэтому я провел небольшое исследование о том, как использовать имя пользователя для аутентификации вместо электронной почты. и я следил за видеоуроком на YouTube, но у меня не получилось, хотя я сделал точно такие же шаги. Это моя структура таблицы пользователей: (id, имя пользователя, пароль, телефон, тип пользователя, Remember_token, created_at, updated_at)
это мой файл login.blade.php:
@extends('layouts.app')
@section('content')
<div class = "container">
<div class = "row justify-content-center">
<div class = "col-md-8">
<div class = "card">
<div class = "card-header">{{ __('Login') }}</div>
<div class = "card-body">
<form method = "POST" action = "{{ route('login') }}">
@csrf
<div class = "form-group row">
<label for = "username" class = "col-md-4 col-form-label text-md-right">{{ __('Pseudo Utilisateur') }}</label>
<div class = "col-md-6">
<input id = "username" type = "text" class = "form-control{{ $errors->has('username') ? ' is-invalid' : '' }}" name = "username" value = "{{ old('username') }}" required autofocus>
@if ($errors->has('username'))
<span class = "invalid-feedback" role = "alert">
<strong>{{ $errors->first('username') }}</strong>
</span>
@endif
</div>
</div>
<div class = "form-group row">
<label for = "password" class = "col-md-4 col-form-label text-md-right">{{ __('Password') }}</label>
<div class = "col-md-6">
<input id = "password" type = "password" class = "form-control{{ $errors->has('password') ? ' is-invalid' : '' }}" name = "password" required>
@if ($errors->has('password'))
<span class = "invalid-feedback" role = "alert">
<strong>{{ $errors->first('password') }}</strong>
</span>
@endif
</div>
</div>
<div class = "form-group row">
<div class = "col-md-6 offset-md-4">
<div class = "form-check">
<input class = "form-check-input" type = "checkbox" name = "remember" id = "remember" {{ old('remember') ? 'checked' : '' }}>
<label class = "form-check-label" for = "remember">
{{ __('Remember Me') }}
</label>
</div>
</div>
</div>
<div class = "form-group row mb-0">
<div class = "col-md-8 offset-md-4">
<button type = "submit" class = "btn btn-primary">
{{ __('Login') }}
</button>
@if (Route::has('password.request'))
<a class = "btn btn-link" href = "{{ route('password.request') }}">
{{ __('Forgot Your Password?') }}
</a>
@endif
</div>
</div>
</form>
</div>
</div>
</div>
</div>
</div>
@endsection
Это user.php
<?php
namespace App;
use Illuminate\Notifications\Notifiable;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Foundation\Auth\User as Authenticatable;
class User extends Authenticatable
{
use Notifiable;
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'username', 'password', 'telephone', 'usertype'
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
}
это логинконтроллер
<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\AuthenticatesUsers;
class LoginController extends Controller
{
/*
|--------------------------------------------------------------------------
| Login Controller
|--------------------------------------------------------------------------
|
| This controller handles authenticating users for the application and
| redirecting them to your home screen. The controller uses a trait
| to conveniently provide its functionality to your applications.
|
*/
use AuthenticatesUsers;
/**
* Where to redirect users after login.
*
* @var string
*/
protected $redirectTo = '/home';
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('guest')->except('logout');
}
public function username(){
return 'username';
}
}
я добавил пользователя через phpmyadmin и попытался войти в систему, но получаю сообщение об ошибке: «Эти учетные данные не соответствуют нашим записям».
Заранее спасибо.
@Md.SukelAli Нет, я не хэшировал и не шифровал
Тогда это не сработает. Laravel всегда хэшировал ваш входной пароль, а затем проверял пароль базы данных. Вы должны использовать хешированный пароль в своей базе данных.
Как мне это сделать?
используйте функцию bcrypt().
Спасибо, как я уже упоминал выше, у меня нет регистрационной формы, поэтому я использовал команду php artisan tinker и получил хешированную версию своего пароля, чем обновил ее в своей базе данных (теперь в моей базе данных есть хешированный пароль), и все еще не я не работаю






Вам нужно изменить значение имени пользователя на Illuminate\Foundation\Auth\AuthenticatesUsers Измените адрес электронной почты на имя пользователя.
public function username()
{
return 'email'; //change this to username
}
Я так и сделал, и это не сработало, я думаю, что метод имени пользователя в LoginController переопределяет метод в AuthenticatesUsers, поэтому результат тот же.
поместите эту функцию имени пользователя в контроллер входа в систему, чтобы переопределить адрес электронной почты по умолчанию в качестве входа
First write "php artisan migrate:fresh" and write the code above Lastly write "php artisan migrate"
class AppServiceProvider extends ServiceProvider
{
/**
* Bootstrap any application services.
*
* @return void
*/
public function boot()
{
Schema::defaultStringLength(150); //database has storage of 150 and is extended to 150;
}
/**
* Register any application services.
*
* @return void
*/
public function register()
{
//
}
}
Вы хешировали свой пароль? когда вы вставляете данные с помощью phpmyadmin