是否可以通过 REST API 检查用户是否有活动/有效的会话?
我正在使用 Java REST 管理客户端。我看到返回的 UserSessionRepresentation
List<UserSessionRepresentation> usr = Keycloak.realm("realmId").users().get("userId").getUserSessions();
Run Code Online (Sandbox Code Playgroud)
但 UserSessionRepresentation 没有我想要的信息。这是可能的?
您可以使用以下地址检查您的会话:
http://keycloakAddressAndPort/auth/realms/develop/protocol/openid-connect/userinfo
Run Code Online (Sandbox Code Playgroud)
如果您的会话不正常,您会看到以下响应(http 状态代码401):
{
"error": "invalid_request",
"error_description": "User session not found or doesn't have client attached on it"
}
Run Code Online (Sandbox Code Playgroud)
如果没问题,您会看到类似这样的内容(http 状态代码200):
{
"sub": "c0c25095-63e7-471d-a39e-f3b157c91fd7",
"email_verified": true,
"name": "Amir Azizkhani",
"preferred_username": "a.azizkhani@...",
"given_name": "Amir",
"family_name": "Azizkhani",
"email": "a.azizkhani@...."
}
Run Code Online (Sandbox Code Playgroud)
完整的邮递员 json:
{
"info": {
"_postman_id": "77ce65c3-948a-4b3d-a97b-b11cd00c593b",
"name": "Spring Keycloak",
"schema": "https://schema.getpostman.com/json/collection/v2.1.0/collection.json"
},
"item": [
{
"name": "openid-connect/userinfo",
"request": {
"auth": {
"type": "bearer",
"bearer": [
{
"key": "token",
"value": "eyJhbGciOiJSUzI1NiIsInR5cC...",
"type": "string"
}
]
},
"method": "GET",
"header": [
{
"key": "accept",
"value": "application/json"
}
],
"url": {
"raw": "http://192.168.131.33:8080/auth/realms/develop/protocol/openid-connect/userinfo",
"protocol": "http",
"host": [
"192",
"168",
"131",
"33"
],
"port": "8080",
"path": [
"auth",
"realms",
"develop",
"protocol",
"openid-connect",
"userinfo"
]
},
"description": "Dont forget to set Bearer value obtains from token request"
},
"response": []
}
]
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
13941 次 |
| 最近记录: |