Laravel Passport注册用户凭据不正确

时间:2017-07-18 15:37:07

标签: laravel api postman laravel-passport

我设置了Laravel Passport,目前我正在尝试使用Post Route注册用户。我确实在RegisterController内创建了Controllers/Api/Auth

因此,我创建了一个客户端表,它看起来像用户表一样兴奋。 如果我调用路由,则会创建客户端,但是我没有获得访问令牌或刷新令牌。

到我的控制器的路线如下(routes / api):

Route::post('register', ['as' => 'register', 'uses' => 'Api\Auth\RegisterController@register']);

我的控制器看起来像这样:

<?php

namespace App\Http\Controllers\Api\Auth;


use App\Client;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Route;
use Laravel\Passport\Client as PClient;

use Illuminate\Http\Request;

class RegisterController extends Controller
{
    private $client;

    public function __construct() {
        $this->client = PClient::find(1);
    }

    public function register(Request $request)
    {
        $this->validate($request, [
            'name' => 'required',
            'email' => 'required|email|unique:users,email',
            'password' => 'required|min:6|confirmed'
        ]);

        $client_user = Client::create([
            'name' => request('name'),
            'email' => request('email'),
            'password' => bcrypt(request('password'))
        ]);

        $params = [
            'grant_type' => 'password',
            'client_id' => $this->client->id,
            'client_secret' => $this->client->secret,
            'username' => request('email'),
            'password' => request('password'),
            'scope' => '*'
        ];

        $request->request->add($params);
        $proxy = Request::create('oauth/token', 'POST');
        return Route::dispatch($proxy);
    }
}

这是我的客户端型号:

class Client extends Model implements AuthenticatableContract,
                                      AuthorizableContract,
                                      CanResetPasswordContract
{
    use Authenticatable, Authorizable, CanResetPassword, HasApiTokens, Notifiable;

    protected $table = 'clients';

    protected $fillable = ['name', 'email', 'password'];

    protected $hidden = ['password', 'remember_token'];

当我尝试使用Postman调用它时,我收到以下错误消息: enter image description here

2 个答案:

答案 0 :(得分:5)

我可能会离开这里,但看起来好像是因为bcrypt('password')电话而使用密码“密码”创建了客户端。

不应该是bcrypt(request('password'))吗?

这可以解释为什么您的凭据在您的请求中是错误的,因为它们是; )

答案 1 :(得分:2)

好的我修好了,如果我使用User模型而不是我的Client模型,后期路线有效,所以我猜想必须有不同的东西。

经过一些研究后我发现需要将模型添加到config/auth.php内的供应商数组中,在我的情况下是客户端模型。

所以第一个需要像这样改变api警卫:

'guards' => [
    'web' => [
        'driver' => 'session',
        'provider' => 'users',
    ],

    'api' => [
        'driver' => 'passport',
        'provider' => 'clients',
    ],
],

这种api路由登录和注册方式只对我的客户采取行动。

现在你需要一个新的提供者,在这种情况下是这样的客户提供者。

'providers' => [
    'users' => [
        'driver' => 'eloquent',
        'model' => App\User::class,
    ],
    'clients' => [
        'driver' => 'eloquent',
        'model' => App\Client::class
    ],
],

如果我打电话给路线,我会得到一个访问令牌+刷新令牌。