Wordpress Laravel 5.8自定义电子邮件和密码列

Wordpress Laravel 5.8自定义电子邮件和密码列,wordpress,laravel,Wordpress,Laravel,我有一个运行WordPress的应用程序,我想使用一个使用Laravel5.8的单独接口来访问它。(不用担心散列) 因此,我希望使用Laravel用户模型中的user_email和user_pass列,而不是来回克隆密码 我试过官方文件所说的: namespace App\Http\Controllers; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; class LoginController exten

我有一个运行WordPress的应用程序,我想使用一个使用Laravel5.8的单独接口来访问它。(不用担心散列)

因此,我希望使用Laravel用户模型中的user_email和user_pass列,而不是来回克隆密码

我试过官方文件所说的:

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;

class LoginController extends Controller
{
    /**
     * Handle an authentication attempt.
     *
     * @param  \Illuminate\Http\Request $request
     *
     * @return Response
     */
    public function authenticate(Request $request)
    {
        $credentials = $request->only('user_email', 'user_pass');

        if (Auth::attempt($credentials)) {
            // Authentication passed...
            return redirect()->intended('dashboard');
        }
    }
}

然后我编辑了刀片文件,但没有用。有什么建议吗

如果您可以在这里使用会话,而不是像在核心PHP上一样使用Auth::attempt,那么它将正常工作。

Laravel提供了一种通过覆盖某些函数来更改Auth(电子邮件、密码)的默认列的方法

在您的用户模型中,添加此函数以覆盖密码的默认列:

App/User.php

/**
 * Get the password for the user.
 *
 * @return string
 */
public function getAuthPassword()
{
    return $this->user_pass;
}
并且,在您的LoginController中,从电子邮件更改为用户电子邮件

App/Http/Controllers/Auth/LoginController.php

/**
 * Get the login username to be used by the controller.
 *
 * @return string
 */
public function username()
{
    return 'user_email';
}
现在您已经覆盖了Laravel的Auth逻辑使用的默认列。但是你还没有完成

LoginController有一个验证用户输入的功能,密码列被硬编码为
password
,因此要更改此功能,您还需要在LoginController中添加以下功能:

App/Http/Controllers/Auth/LoginController.php

/**
 * Validate the user login request.
 *
 * @param  \Illuminate\Http\Request  $request
 * @return void
 *
 * @throws \Illuminate\Validation\ValidationException
 */
protected function validateLogin(Request $request)
{
    $request->validate([
        $this->username() => 'required|string',
        'user_pass' => 'required|string',
    ]);
}


/**
 * 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(), 'user_pass');
}
下一步是创建一个自定义提供程序,我们称之为
CustomUserProvider
,它将取代默认的
EloquentUserProvider
,并覆盖密码字段

App/Providers/CustomUserProvider.php

<?php
namespace App\Providers;

class CustomUserProvider extends EloquentUserProvider
{
    /**
     * Retrieve a user by the given credentials.
     *
     * @param  array  $credentials
     * @return \Illuminate\Contracts\Auth\Authenticatable|null
     */
    public function retrieveByCredentials(array $credentials)
    {
        if (empty($credentials) ||
           (count($credentials) === 1 &&
            array_key_exists('user_pass', $credentials))) {
            return;
        }

        // First we will add each credential element to the query as a where clause.
        // Then we can execute the query and, if we found a user, return it in a
        // Eloquent User "model" that will be utilized by the Guard instances.
        $query = $this->createModel()->newQuery();

        foreach ($credentials as $key => $value) {
            if (Str::contains($key, 'user_pass')) {
                continue;
            }

            if (is_array($value) || $value instanceof Arrayable) {
                $query->whereIn($key, $value);
            } else {
                $query->where($key, $value);
            }
        }

        return $query->first();
    }

    /**
     * Validate a user against the given credentials.
     *
     * @param  \Illuminate\Contracts\Auth\Authenticatable  $user
     * @param  array  $credentials
     * @return bool
     */
    public function validateCredentials(UserContract $user, array $credentials)
    {
        $plain = $credentials['user_pass'];

        return $this->hasher->check($plain, $user->getAuthPassword());
    }
}
最后更新配置信息
config/auth.php
,并将驱动程序从
eloquent
更改为
custom
(这就是我在上面命名它的方式;您可以将它更改为任何您想要的)。因此,
config/auth.php
文件应该有以下内容:

'providers' => [
    'users' => [
        'driver' => 'custom',
        'model' => App\User::class,
    ],
],
希望有帮助


注意

用户表中的列是否命名为
user\u email
,以及
user\u pass
?如果是这样,您需要指定它们,因为它们不是默认值<代码>身份验证::尝试(['user\u email'=>$request->user\u email,'user\u pass'=>$request->user\u pass])。您还需要对用户模型进行更改。
'providers' => [
    'users' => [
        'driver' => 'custom',
        'model' => App\User::class,
    ],
],