This article provides a detailed guide on integrating Keycloak for authentication and authorization in a Java-based resource server. The integration utilizes OAuth2 and OpenID Connect protocols, with Keycloak as the identity provider (IdP). The Java application functions as a resource server, validating access tokens.
Prerequisites for Keycloak integration
Before starting, ensure you have the following:
- Keycloak installed and running (locally or via Docker).
- A Keycloak realm and clients configured for both the backend and frontend applications.
- A Java (Spring Boot) project for the backend.
- Basic knowledge of OAuth2/OpenID Connect protocols.
Keycloak integration implementation
Keycloak setup
Step 1: Create a Keycloak Realm
- Log in to the Keycloak Admin Console.
data:image/s3,"s3://crabby-images/bd194/bd194b7b4e37d5c1a7998618077e24cb703320af" alt=""
- From the sidebar, click “Add Realm”.
data:image/s3,"s3://crabby-images/cbddb/cbddb2bdc1af9b99a86c44b5478ed0ae638c9cb2" alt=""
- Enter a realm name (e.g., authentication) and click Save.
Step 2: Create a Client for the Java Resource Server
- Select a Realm that you want to setup
- Go to Clients and Click on Create client
data:image/s3,"s3://crabby-images/7b87f/7b87f849b9c0c8cf35049dfe903e80124f0c9391" alt=""
- Click “Create”
- Configure the client with the following:
At the general setting section:
- Client type: OpenID Connect
- Client ID: input your client ID (e.g., custom-authentication)
At the capability config: left by default
- Creating Roles for spring boot authorization process:
Keycloak provides a convenient way to create roles, assign them to users, and manage application roles effectively. In Keycloak mainly there are two types of roles.
- Client Roles: These roles are specific to a particular client application. Clients are created in the Keycloak administration interface and can be assigned to users within a specific client.
- Realm Roles: These roles represent a realm, which can be a real or virtual application domain. Realm roles are applicable to all clients within a realm and can be assigned to users across the entire realm.
And in addition to these, there are composite roles. A composite role is not a role type but a special role that includes multiple authorities.
Firstly, we will create two client roles called [manage_customer] and [manage_staff] for customer and staff management. To do this, I click on the client that I created (custom-authentication) and then click on Create role :
data:image/s3,"s3://crabby-images/8656e/8656eb1c535f6bfae0b0c8c02d2fb9410d9f00e9" alt=""
Role created in the Client has its composite status set to False by default
data:image/s3,"s3://crabby-images/ddc1f/ddc1f836c110ac9a873bc50f3b242476577c95ce" alt=""
After that we will create two realm roles. To do this, navigate to the Realm Roles page to create roles.
data:image/s3,"s3://crabby-images/80c8e/80c8ea3619306a013b3a8a9d713fec463eb61e8c" alt=""
Next, create the operation role and associate it with two created client-role that already created in the previous step
data:image/s3,"s3://crabby-images/2c889/2c8897ada4ca3a019245c5f4013f3f2a6ea6e8c4" alt=""
- Creating Users:
The last part that needs to be added is the user element. We go to the Users page and create two users and assign created Realm role to these customers:
Customer-management admin: with role manage_customer
Staff-management admin: with role manage_staff
data:image/s3,"s3://crabby-images/e6e90/e6e90356fbff2633e2f67473520ae00185613102" alt=""
data:image/s3,"s3://crabby-images/0bc39/0bc3971089c95035a7c7e67fe5b592282480f0f4" alt=""
Java Resource Server Setup
Step 1: Add Dependencies
data:image/s3,"s3://crabby-images/502eb/502eb5a49f814ef01eda9bfc7799eeca8d918377" alt=""
Step 2: Configure application.yml
data:image/s3,"s3://crabby-images/ac781/ac781666ebd0dbee7af631e6a53faa310baa103b" alt=""
data:image/s3,"s3://crabby-images/aafc5/aafc50c251984f98efeeff92acec9cfe19209c50" alt=""
Step 4: Controller Test
data:image/s3,"s3://crabby-images/a24d8/a24d890f47630cb5298697e0f99515e7477144a3" alt=""
data:image/s3,"s3://crabby-images/27932/27932e12f40c6e2a7dcf5a522899ab8f0f10c941" alt=""
Finally, by reading this article carefully and following the guidelines above step-by-step, I strongly believe you can implement Keycloak integration with the Java source server. If you need someone to implement your project relating to Keycloak, Let’s learn more about our Custom Web/App Implementation Service and contact us. We are always here to help!