你应该在请求的 api 加上 Headers 头信息
Authorization: Bearer access_token
在相应的 api 中使用 auth:api 中间件进行 access_token 认证;通过 auth('api')->user() 取得当前用户;access_token 认证不通过会返回 401 Unauthenticated
@小恪守
我是用client_credentials类型,没有用户的呀。
grant_type: 'client_credentials',
client_id: 1,
client_secret: 'K345345m0Ld4D4CQiorKuG8flsMpQ5wzsI8jeva',
scope: ''
@waney client_credentials 授权方式是对客户端的认证,通常适合一些不需要用户体系但只对指定客户端开放 api 的场景,如果需要取到用户,一般可以采用 password 授权方式
@waney 对于客户端认证 client_credentials ,你应该注册一个 passport 的中间件 CheckClientCredentials,这个中间件用于对拥有访问令牌的客户端进行授权认证。
# App/Http/Kernel.php
protected $routeMiddleware = [
...
'client.credentials' => \Laravel\Passport\Http\Middleware\CheckClientCredentials::class,
]
# routes/api.php
Route::middleware('client.credentials')->get();
@waney 但是我还需要其他的中间件 api:auth我自己定义的中间件, 里面包含了 auth:api 和 api.auth。我单单用 auth:api 确实给我报的是 401 错误,但是我 dingo 接口里面不能用 $request->user() 得到用户信息。
@waney 很奇怪,我自己写了一个 provider 如果 api.auth 就调用到了, auth:api 就调用不到, 500 错误是从 \vendor\laravel\framework\src\Illuminate\Auth\Middleware\Authenticate.php 这里报出来。
@tiandaye 我解决了,不知道你解决没,下面给出解决方法
在AppServiceProvider的boot方法里,注册上这一段代码
// 注册dingo针对token错误返回错误编码
app('Dingo\Api\Exception\Handler')->register(function(AuthenticationException $exception) {
// 处理401错误
});
反正laravel5.5不用在接入dingo/api了,所以,这个算是历史遗留问题。
关于 LearnKu
推荐文章: