gpt4 book ai didi

java - 如何将 Keycloak 与 PKCE 结合使用

转载 作者:行者123 更新时间:2023-12-02 09:23:18 28 4
gpt4 key购买 nike

我尝试使用 pkce 和授权代码流从 keycloak 获取 token ,但没有成功。

请求参数(来自 postman ):

curl -X POST \
http://keycloak-ar.uat.com/auth/realms/myrealm/protocol/openid-connect/token \
-H 'Accept: */*' \
-H 'Accept-Encoding: gzip, deflate' \
-H 'Authorization: Basic YWJyYWFvLxF1ZWlyb3o6MTIz' \
-H 'Cache-Control: no-cache' \
-H 'Connection: keep-alive' \
-H 'Content-Length: 172' \
-H 'Content-Type: application/x-www-form-urlencoded' \
-H 'Host: keycloak-ar.uat.com' \
-d 'grant_type=authorization_code&client_id=spring-boot-app&username=apiuser&client_secret=cd78e82a-e86a-4bf3-a3d7-7c01cec49396&code=qjrzSW9gMiUgpUvqgEPE4_-8swvyCtfOVvg55o5S_es'

key 斗篷日志:

22:50:01,962 WARN  [org.keycloak.events] (default task-146) type=CODE_TO_TOKEN_ERROR, realmId=myrealm, clientId=spring-boot-app, userId=null, ipAddress=10.128.2.1, error=invalid_code, grant_type=authorization_code, client_auth_method=client-secret

最佳答案

无法发表评论,因此添加作为答案。

-d 'grant_type=authorization_code&client_id=spring-boot-app&username=apiuser&client_secret=cd78e82a-e86a-4bf3-a3d7-7c01cec49396&code=qjrzSW9gMiUgpUvqgEPE4_-8swvyCtfOVvg55o5S_es'

有几件事:
1) client_secret 是可选的
2) 缺少redirect_uri。它是必需的,并且必须与请求授权代码时使用的完全相同。

关于用户名,肯定不需要,但不能说它的存在是否会导致问题。最好将其删除。

关于java - 如何将 Keycloak 与 PKCE 结合使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58522469/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com