java - 在 FusionAuth 中使用授权代码授予请求响应访问令牌调用时未获得刷新令牌
问题描述
我正在使用FusionAuth进行身份验证。我在 FusionAuth 中创建了一个应用程序。它已配置 oAuth。
这是我的 FusionAuth 登录页面之一的授权 URL。
一旦我点击链接并输入用户名和密码,我就会在我的 java jersey api 中获得配置的回调 url 上的回调。
我在回叫请求中得到以下详细信息。
code - dZgq5Xd0YmAQXZ2JIzkih832iojimgLUPwT7yoH9-TY
locale - en_US
userState - AuthenticatedNotRegistered
在这里,我使用Scribe Java 库进行 OAuth 身份验证
我使用给定的授权代码调用 Scribe java 库来获取访问令牌调用,并且 grant_type 是 authentication_code。
在这里,此调用成功,我在响应中得到以下详细信息。
{
"access_token": "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6ImRRZTA1Uk1vN19oVjZUUnpLVUQ1aXpRU2NSOCJ9.eyJhdWQiOiI5ZWNjNTRiNy02Zjc5LTQxMDUtYTIwOC1jYTYxZTYxNTdiNTgiLCJleHAiOjE1Nzc3MTg0NjgsImlhdCI6MTU3NzcxODM0OCwiaXNzIjoiYWNtZS5jb20iLCJzdWIiOiI3ZWE3OWRhZi1hZjExLTQ1MTUtODljYS1iOGFjYTFjN2I5YTEiLCJhdXRoZW50aWNhdGlvblR5cGUiOiJQQVNTV09SRCIsImVtYWlsIjoiZGhhdmFsYmhvb3Q5M0BnbWFpbC5jb20iLCJlbWFpbF92ZXJpZmllZCI6dHJ1ZSwicHJlZmVycmVkX3VzZXJuYW1lIjoiZGhhdmFsYmhvb3QifQ.eA0Xi6nEZhWaTMd-P26ESdE3NsyXNRNVBKBdBvHxvzfHgXYJiN2pf-16mY8JK-4-1g3vZF7Cwv-SkP4iZAIJCYYc3uBW8Qlcjjn9cyi7_RggBBBsErcs2acRIt-D5NpnVJfkxHwGAs9fO6a2Win98GGYyv1nzBG9OhWkyZJTy4QxzlgXNrkQIzTuzRwLkRFzKCT95pqfsOYb_MXPuAksg5q1SHIj8qtbO7EO-vMbpmiok1C-Wflbiq2X_tq17QBKbO4JAMLm9_pCZse1tqLyNP4fIh3VHTz7OdbbXvug2Tpk_yTWLVL_29XC87-91R5iXeezLjADkdi1yXMUdHioOw",
"expires_in": 119,
"token_type": "Bearer",
"userId": "7ea79daf-af11-4515-89ca-b8aca1c7b9a1"
}
在这里,无论如何,用户第一次登录或任何情况下,我都没有得到 refresh_token。这是JWT 令牌,我已将到期时间减少到 120 秒。
在应用程序 OAuth 设置中,我启用了生成刷新令牌选项。
我这里唯一的问题是,我没有收到刷新令牌。帮我解决这个问题。
谢谢你。
解决方案
要通过授权代码授予获得刷新令牌,您需要请求offline_access
范围。
https://fusionauth.io/docs/v1/tech/oauth/endpoints#authorization-code-grant-request
您可以按如下方式修改您的请求(添加换行符以提高可读性)
http://localhost:9011/oauth2/authorize?
scope=offline_access
&prompt=consent
&response_type=code
&client_id=9ecc54b7-6f79-4105-a208-ca61e6157b58
&redirect_uri=http%3A%2F%2Flocalhost%3A8080%2Fipos%2Frest%2FfusionAuth%2FcallBack
作为旁注,添加prompt=consent
很好,但它不会影响请求,因为这在 FusionAuth 中尚不可用。如果这是您希望在即将发布的版本中看到的内容,请对功能请求进行投票。https://github.com/FusionAuth/fusionauth-issues/issues/411
推荐阅读
- python - Seaborn 热图:使用可点击的超链接进行注释
- javascript - ajax django表单仅提交部分数据
- python - Django - 即时创建 CSV 并将其保存到文件系统和模型文件字段
- django - 我应该如何使用 DRF 发布和序列化数组?
- .net - 为秒表添加时间
- python - 如何在实例变量的更改上执行代码?
- python-3.x - Python 3套接字客户端未连接到服务器
- javascript - 在我的机器和 AWS-Lambda 上工作时,Node.js 函数会给出不同的结果
- highcharts - Highcharts 系列未加载
- opengl - 是否可以在同一个着色器程序中使用不同的顶点数组对象?