Laravel中使用passport实现用户注册

安装passport

composer require laravel/passport ‘7.5.0’

  • 注:我安装的时候没有一开始没有加版本号,然后就报了如下错:
    Installation failed, reverting ./composer.json to its original content.
    加了版本号就好了,但我后来过了段时间尝试的时候,发现不加也可以,加了反而报错,23333
执行迁移

php artisan migrate

这一步我也不知道该怎么说了

php artisan passport:install

修改文件
  • User模型中,加入 use Laravel\Passport\HasApiTokens;然后在类中引用该traituse Notifiable,HasApiTokens;
  • Providers/AuthServiceProvider.phpboot方法中加入:
    Passport::routes();
  • 修改config/auth.php文件中的guards中的api中的driverpassport
为了实现注册后就直接登录,还需安装guzzlehttp

版本可以自选

composer require guzzlehttp/guzzle '6.5.2'

注册代码
<?php

namespace App\Http\Controllers;

use App\Http\Requests\RegisterUserRequest;
use App\User;
use GuzzleHttp\Client;

class RegisterController extends Controller
{
    private $http;

    public function __construct(Client $http)
    {
        $this->http = $http;
    }

    public function register(RegisterRequest $request)
    {
        // 创建用户
        User::create([
            'name' => $request->input('name'),
            'email' => $request->input('email'),
            'password' => bcrypt($request->input('password'))
        ]);

        // 获取创建用户的access_token作为登录凭证,登录的时候其实也是这样获取access_token的
        $response = $this->http->post('http://api.test/oauth/token', [
            'form_params' => [
                "grant_type" => "password",
                // 此处用的是用户邮箱验证
                // 后来我尝试使用上面创建用户后返回的信息,如赋值给$user之后,下面的username和password使用的是$user->email和$user->password的时候,会报如下的错 : Client error: `POST http://taking.test/oauth/token` resulted in a `400 Bad Request` response:\n{\"error\":\"invalid_grant\",\"error_description\":\"The provided authorization grant (e.g., authorization code, resource owner (truncated...)\n
                // 但是使用$request的话就正确
                "username" => $request->input('email'),
                "password" => $request->input('password'),
                // 此处是oauth_clients数据表中有两个值,用的是id=2的值
                "client_id" => "2",
                "client_secret" => "LQ1a8TAUMjXw3CBpwGR2uLXlNWOuqJOG7Cpsnprq",
                // 设置api的范围权限全局访问
                "scope" => "*"
            ]
        ]);

        $token = json_decode((string)$response->getBody(), true);

        return response()->json([
            'token' => $token
        ], 201);
    }
}
  • 返回内容如下

laravel实现passport 用户注册登录

  • 在返回的内容中有access_token,可以拿他获取用户信息

laravel实现passport 用户注册登录

  • 其中passport也是可以实现自定义使用用户名或者手机号登录的,只需要在用户模型中复写一个方法即可,如下:
public function findForPassport($username)
{
return $this->orwhere('name', $username)->orwhere('email',$username)->first();
}
  • 这个时候是有一个需要注意的地方的,上面修改的时候,我一开始用的where并不是orwhere,然后就会报一个错,如下

“message”: "Client error: POST http://taking.test/oauth/token resulted in a 400 Bad Request response:\n{“error”:“invalid_grant”,“error_description”:“The provided authorization grant (e.g., authorization code, resource owner (truncated…)\n”,
“exception”: “GuzzleHttp\Exception\ClientException”

  • 我的解决办法就是改用orwhere,这样既可以使用用户名登录,也可以使用邮箱登录,完美

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值