On this page
Validate Access Tokens
This guide explains why access token validation is important and how to validate and decode the access token.
Learning outcomes
- Understand token validation.
- Understand what to check when validating tokens.
- Decode access tokens.
- Validate access tokens remotely.
About access token validation
If you're building a modern app or API, you want to know if your end user is authenticated. This is important to give context or to protect APIs from unauthenticated users. You can use Okta to authenticate your end users and issue them signed access and ID tokens. Your app can then use these tokens. It's important that your app uses only the access token to grant access, and not the ID token. See Access tokens vs ID tokens.
After signed tokens are issued to end users, they can be passed to your app for validation. There are two ways to verify a token: locally or remotely with Okta. The token is signed with a JSON Web Key (JWK) using the RS256 algorithm. To validate the signature, Okta provides your app with a public key that you can use.
Note: If you have a new Okta Integrator Free Plan org (opens new window) and plan to use the
defaultcustom authorization server, check that it has an access policy. Add an access policy if it's not there. See Create access policies (opens new window).
- To jump straight to the local validation steps: What to check when validating an access token
- To see how to validate a token directly with Okta: Validate a token remotely with Okta
Note: Okta is the only app that should consume or validate access tokens from the org authorization server. Org authorization servers have the following
issuerformat:https://{yourOktaOrg}. Consider these access tokens as opaque strings because their content is subject to change at any time. Therefore, any attempts by your app to validate the tokens may not work in the future.
Access tokens vs ID tokens
Access tokens are intended for authorizing access to a resource. It's important that the resource server (your server-side app) accepts only an access token from a client.
ID tokens, on the other hand, are intended for authentication. They provide information about the resource owner so that you can verify that they're who they say they are. Authentication is important to clients. Because of this, when a client makes an authentication request, the ID token that's returned contains the client_id in the ID token's aud claim.
What to check when validating an access token
The high-level overview of validating an access token looks like this:
- Retrieve your Okta JSON Web Keys (JWK) (opens new window), which your app should check periodically and cache.
- Decode the access token, which is in JSON Web Token (JWT) (opens new window) format.
- Verify the signature used to sign the access token.
- Verify the claims found inside the access token.
Retrieve the JSON Web Keys
Decode and validate the access token
Decode the access token, which is in JWT format. This involves the following steps:
- Verify the token signature.
- Verify the claims.
Validate a token remotely with Okta
Alternatively, you can validate an access or refresh token using the Token Introspection endpoint: Introspection request (opens new window). This endpoint takes your token as a URL query parameter and returns a simple JSON response with a Boolean active property.
This involves a network request that is slower for performing validation. But, you can use it when you want to guarantee that the access token hasn't been revoked.