是否可以通过 Keycloak 中的 REST API 检查用户是否具有活动/有效会话?

Max*_*ino 4 java keycloak

是否可以通过 REST API 检查用户是否有活动/有效的会话?

我正在使用 Java REST 管理客户端。我看到返回的 UserSessionRepresentation

List<UserSessionRepresentation> usr = Keycloak.realm("realmId").users().get("userId").getUserSessions();
Run Code Online (Sandbox Code Playgroud)

但 UserSessionRepresentation 没有我想要的信息。这是可能的?

ami*_*110 5

您可以使用以下地址检查您的会话:

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)