Это может быть повторяющийся вопрос о том, почему auth: попытка всегда возвращает false, но, несмотря на поиск ответов, я не могу решить свою проблему дальше.
У меня есть таблица учеников с идентификатором std_id, электронной почтой std_email и паролем std_password. Чтобы преодолеть поле пароля по умолчанию, я прошел через некоторые ответы и рекомендую использовать эту функцию для переопределения имени поля
public function getAuthPassword() {
return $this->std_password;
}
и функция попытки
public function authenticate(Request $request)
{
if (Auth::attempt(['std_email' => $request['std_email'], 'password' => $request['std_password']])){
return response()->json([
'validated' => true
]);
}else{
return response()->json([
'validated' => false
]);
}
}
Итак, я обновил два файла, auth / LoginController.php
<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\AuthenticatesUsers;
use \Illuminate\Support\Facades\Auth;
use Illuminate\Http\Request;
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 authenticate(Request $request)
{
if (Auth::attempt(['std_email' => $request['std_email'], 'password' => $request['std_password']])){
return response()->json([
'validated' => true
]);
}else{
return response()->json([
'validated' => false
]);
}
}
}
и модель User как
<?php
namespace App;
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
class User extends Authenticatable
{
use Notifiable;
protected $primaryKey = "std_id";
protected $table = "students";
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'std_email', 'std_password',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
//'std_password', 'remember_token',
];
public function getAuthPassword() {
return $this->std_password;
}
}
Я убедился, что в режиме пользователя я установил первичный ключ как std_id, а таблицу - как студентов.
Кроме того, когда я регистрирую студента, я использую bcrypt для хеширования пароля и сохранения его в БД.
public function create(Request $request){
$account_exists = $this->check_account_exists($request['email']);
if($account_exists){
return response()->json(['account'=>true]);
}else{
DB::table('students')->insert([
'std_fname' => $request['first_name'],
'std_lname' => $request['last_name'],
'std_email' => $request['email'],
'std_password' => bcrypt($request['std_password']),
'group_id' => $request['group'],
'std_isActive' => 1
]);
return response()->json(['created'=>true]);
}
}
На данный момент я не получаю никаких ответов, почему метод попытки не работает, поскольку я убедился, что информация для входа верна? Вы видите, пропустил ли я что-нибудь еще?
Спасибо!