Securing Spring Boot REST API with Keycloak

This video is a companion of my previous blog which secures a React application via keycloak and is available at https://gtw1526.blogspot.co...


This video is a companion of my previous blog which secures a React application via keycloak and is available at https://gtw1526.blogspot.com/2019/08/how-to-secure-react-app-with-keycloak.html.

Before we begin, don’t forget to subscribe to my channel and hit the bell icon to get notified on my new video uploads.

Needless to say, we need to set up and run the React project, before we can experiment on this one. So please go over to the previous article.

At this point, I assume that you already have a running and configured Keycloak in docker as well as the React project.

Configure Keycloak Server

  1. Run Keycloak on terminal docker run -p 8080:8080 -e KEYCLOAK_USER=admin -e KEYCLOAK_PASSWORD=admin jboss/keycloak. Note that I’m running my instance on another machine thus I’ll be using a network IP.
  2. Import the realm configuration as well as the users from the Spring Keycloak with REST API project, config folder. See reference below for the link.
  3. Make sure that the primereact-client is set to accessType=confidential.
  4. Check that the keycloak.json in the react project matches the primereact-client, specially the credential secret.
  5. Import the users in the same folder. It should import 3 users: kerri, admin, and norole.

Configure the Spring Project

  1. Check out the Spring project from Github.
  2. Configure Keycloak.
    1. Via application.yml - we will be using this.
    2. Via keycloak.json
  3. Add keycloak-spring-boot-starter dependency in the project’s pom to secure the project with Keycloak.
  4. Override the class KeycloakWebSecurityConfigurerAdapter.
  5. Security constraints can be configured via
    1. application.yml
    2. KeycloakWebSecurityConfigurerAdapter class
    3. PreAuthorize annotation
Let’s run the application, log in and it should navigate us to http://localhost:3000/customers. In this page, we should be able to fetch the list of customers.

To test the role constraints the following users should yield these results. These can be observed using the firebug plugin in firefox:
  1. User kerri
    1. Role user - ok
    2. Role admin - ko
  2. User admin
    1. Role user - ok
    2. Role admin - ok

References



COMMENTS

Nome

angular,1,bigdata,1,course-spring,27,courses,6,database,2,docker,1,java,17,kafka,1,keycloak,4,microservices,4,mysql,1,neworking,1,pinned,1,react,2,server management,3,shared drive,1,spring,7,synology,1,
ltr
item
Get to Work: Securing Spring Boot REST API with Keycloak
Securing Spring Boot REST API with Keycloak
https://i.ytimg.com/vi/4b-wZN-6SsU/0.jpg
https://i.ytimg.com/vi/4b-wZN-6SsU/0.jpg
Get to Work
https://gtw1526.blogspot.com/2019/08/securing-spring-boot-rest-api-with.html
https://gtw1526.blogspot.com/
https://gtw1526.blogspot.com/
https://gtw1526.blogspot.com/2019/08/securing-spring-boot-rest-api-with.html
true
27950497214016359
UTF-8
Loaded All Posts Not found any posts VIEW ALL Readmore Reply Cancel reply Delete By Home PAGES POSTS View All RECOMMENDED FOR YOU LABEL ARCHIVE SEARCH ALL POSTS Not found any post match with your request Back Home Sunday Monday Tuesday Wednesday Thursday Friday Saturday Sun Mon Tue Wed Thu Fri Sat January February March April May June July August September October November December Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec just now 1 minute ago $$1$$ minutes ago 1 hour ago $$1$$ hours ago Yesterday $$1$$ days ago $$1$$ weeks ago more than 5 weeks ago Followers Follow THIS PREMIUM CONTENT IS LOCKED STEP 1: Share to a social network STEP 2: Click the link on your social network Copy All Code Select All Code All codes were copied to your clipboard Can not copy the codes / texts, please press [CTRL]+[C] (or CMD+C with Mac) to copy Table of Content