你应该在请求的 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了,所以,这个算是历史遗留问题。
推荐文章: