我目前正在开展第一个laravel项目,我正面临一个问题。
如果您有使用laravel的经验,您可能知道通过调用php artisan make:auth
,您将获得一个处理登录和注册的预定义机制。
这个机制设置为理解一些常用词,以便自动完成整个过程。
在我的情况下发生的问题是我使用oracle db并且它不会让我有一个名为password
的表列,因为它是一个系统关键字并且它会抛出尝试插入用户时出错。
到目前为止,我已尝试将password
列更改为passwd
,并按照预期在我的注册表单中工作。用户行已成功插入,我的页面被重定向到/ home。
但是当我尝试注销然后重新登录时,我收到此错误,告诉我我的凭据不正确。
至于我的代码,我已更改了我的RegisterController.php
,因此需要使用用户名而不是电子邮件
protected function validator(array $data)
{
return Validator::make($data, [
'username' => 'required|max:50|unique:ECON_USERS',
'passwd' => 'required|min:6|confirmed',
]);
}
protected function create(array $data)
{
return User::create([
'username' => $data['username'],
'passwd' => bcrypt($data['passwd'])
]);
}
用户$可填写
protected $fillable = [
'username', 'passwd'
];
我猜测Auth正在尝试使用email
而不是username
进行身份验证,或者Auth正在搜索password
而不是passwd
答案 0 :(得分:20)
要让username
代替email
,您可以在 LoginController.php
/**
* Get the login username to be used by the controller.
*
* @return string
*/
public function username()
{
return 'username';
}
对于passwd
而不是password
,您可以在 App \ User.php
/**
* Get the password for the user.
*
* @return string
*/
public function getAuthPassword()
{
return $this->passwd;
}
login.blade.php :将email
输入替换为username
但不更改{{1}的输入名称}。
答案 1 :(得分:2)
在app/Http/Controllers/Auth/LoginController
中通过添加:
/**
* Validate the user login request.
*
* @param \Illuminate\Http\Request $request
* @return void
*/
protected function validateLogin(Request $request)
{
$this->validate($request, [
$this->username() => 'required', 'passwd' => 'required',
]);
}
不要忘记添加use Illuminate\Http\Request;
您可能需要将此添加到LoginController
。
/**
* Get the needed authorization credentials from the request.
*
* @param \Illuminate\Http\Request $request
* @return array
*/
protected function credentials(Request $request)
{
return $request->only($this->username(), 'passwd');
}
应该这样做。
答案 2 :(得分:1)
使用它。这对我有用。
到目前为止,我已经更改了User.php
public function getAuthPassword(){
return $this->senha;
}
和
public function setPasswordAttribute($value)
{
$this->attributes['password'] = bcrypt($value);
}
同样在LoginController.php上
public function username()
{
return 'usuario';
}
答案 3 :(得分:0)
在上述答案旁边的Laravel 5.7中,您必须更改EloquentUserProvider类。在文件中搜索(第107,117和140行)中的“密码”单词,您发现了“密码”单词并用新名称进行了更改,这全都可以解决。
public function getAuthPassword(){ return $this->new_password_name; }
protected function validateLogin(Request $request){ $this->validate($request, [ $this->username() => 'required', 'new_password_name' => 'required', ]); } protected function credentials(Request $request) { return $request->only($this->username(), 'new_password_name'); } public function username() { return 'new_username';//or new email name if you changed }
validateCredentials
和retrieveByCredentials
函数内部的EloquentUserProvider类中,用新名称更改“密码”单词。 编辑:我更改了EloquentUserProvider
类,但是如果您认为更改laravel类是一种不好的做法,则可以创建自定义提供程序并覆盖retrieveByCredentials
和validateCredentials
自定义提供程序中的功能。
答案 4 :(得分:0)
如果使用最新版本。我像下面的代码一样针对自定义密码字段返回它。最后,我正在使用Lumen 6.x,尽管它也适用于当前版本的Laravel。
/**
* Get the custom password field for the user.
*
* @return string
*/
public function getAuthPassword()
{
return $this->custom_password_field_here;
}
答案 5 :(得分:0)
IN自定义控制器
public function login(Request $request){
if (Auth::attempt(['email' => $request->email,'password' => $request->password], false)){
return redirect()->intended(route('subportal.dashboard'));
}
return $this->sendFailedLoginResponse($request);
}
protected function validateLogin(Request $request)
{
$this->validate($request, [
$this->username() => 'required', 'password' => 'required',
]);
}
/**
* Get the login username to be used by the controller.
*
* @return string
*/
public function username()
{
return 'email';
}
在App / Users.php中
public $table = "customer";
protected $primaryKey = 'cust_id';
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'pass', 'email','record_date',
];
public function getAuthPassword() {
return $this->pass;
}
答案 6 :(得分:-1)
在您的AuthController.php(位于app / http / Controllers / Auth中)
public function postLogin(Request $request)
{
$this->validate($request, [
'username' => 'required',
'password' => 'required',
]);
$credentials = ($request->only('username', 'password'));
if ($this->auth->attempt($credentials)) {
//do something, credentials is correct!
}
return "Ops! snap! seems like you provide an invalid login credentials";
}