This is my first time working with Keycloak. I have prepared a Keycloak instance in my local machine in which I can create realm's, clients etc.
I found React + Keycloak examples of use, but none of them used PKCE flow.
I don't know how to configure Keycloak and React. I only know that the client application must be able to generate a code verifier and a code challenge.
I am looking for a simple example of implementing authorization using react and Keycloak which should follow the OAuth 2.0 Authorization Code Grant with PKCE Flow or tips on what to do on the React side and what on the Keycloak side to implement OAuth 2.0.
What I want to do:
- Setting up a Keycloack instance (ready)
- Registration of a public client in Keycloack (ready)
- Implementation of a simple login scenario in web (the scenario follow OAuth 2.0 Authorization Code Grant with PKCE Flow)
This is my first time working with Keycloak. I have prepared a Keycloak instance in my local machine in which I can create realm's, clients etc.
I found React + Keycloak examples of use, but none of them used PKCE flow.
I don't know how to configure Keycloak and React. I only know that the client application must be able to generate a code verifier and a code challenge.
I am looking for a simple example of implementing authorization using react and Keycloak which should follow the OAuth 2.0 Authorization Code Grant with PKCE Flow or tips on what to do on the React side and what on the Keycloak side to implement OAuth 2.0.
What I want to do:
- Setting up a Keycloack instance (ready)
- Registration of a public client in Keycloack (ready)
- Implementation of a simple login scenario in web (the scenario follow OAuth 2.0 Authorization Code Grant with PKCE Flow)
1 Answer
Reset to default 7(Old Keycloak UI)
Go to your Realm, and then to client and select your client:
- Set
Access Type
topublic
- Enabled
Standard Flow Enabled
- Add the appropriate
Valid redirect URIs
andWeb origins
- Go to
Advanced Settings
and in the fieldProof Key for Code Exchange Code Challenge Method
and selectS256
, and then click onSave
.
(New Keycloak UI)
Select your Realm, and then go to client and click in your client:
- Set
Client authentication
toOFF
- In
Authentication Flow
selectStandard flow
- Add the appropriate
Valid redirect URIs
andWeb origins
- Click on the
Save
button - Go to
Advanced
tab - Go to the section
Advanced Settings
and in the fieldProof Key for Code Exchange Code Challenge Method
and selectS256
, and then click onSave
.
On the adaptor of your React application add "enable-pkce": true.
From the keycloak documentation:
The KeycloakInstalled adapter supports the PKCE [RFC 7636] mechanism to provide additional protection during code to token exchanges in the OIDC protocol. PKCE can be enabled with the "enable-pkce": true setting in the adapter configuration. Enabling PKCE is highly remended, to avoid code injection and code replay attacks.