Code Monkey home page Code Monkey logo

okta-spring-boot-oauth-example's Introduction

Spring Boot, OAuth 2.0, and Okta Example

A Spring Boot example app that shows how to implement single sign-on (SSO) with Spring Security and Okta.

Please read Get Started with Spring Boot, OAuth 2.0, and Okta to see how this app was created.

Prerequisites: Java 8.

Okta has Authentication and User Management APIs that reduce development time with instant-on, scalable user infrastructure. Okta's intuitive API and expert support make it easy for developers to authenticate, manage and secure users and roles in any application.

Getting Started

To install this example application, run the following commands:

git clone https://github.com/oktadeveloper/okta-spring-boot-oauth-example.git
cd okta-spring-boot-oauth-example

This will get a copy of the project installed locally. To run the example, install Spring CLI and run the following command:

spring run helloOAuth.groovy

Create an OIDC App in Okta

You will need to create an OIDC App in Okta to get a clientId and clientSecret.

Log in to your Okta Developer account (or sign up if you don’t have an account) and navigate to Applications > Add Application. Click Web, click Next, and give the app a name you’ll remember. Click Done and copy the clientId and clientSecret into server/src/main/resources/application.yml.

security:
  oauth2:
    client:
      clientId: {clientId}
      clientSecret: {clientSecret}
      accessTokenUri: https://{yourOktaDomain}.com/oauth2/default/v1/token	
      userAuthorizationUri: https://{yourOktaDomain}.com/oauth2/default/v1/authorize 
      scope: openid profile email
    resource:
      # from your Auth Server's metadata at .well-known/openid-configuration
      userInfoUri: https://{yourOktaDomain}.com/oauth2/default/v1/userinfo

NOTE: The value of {yourOktaDomain} should be something like dev-123456.oktapreview. Make sure you don't include -admin in the value!

After modifying this file, restart your app and you'll be redirect to Okta to login.

Links

This example uses Spring Security OAuth to integrate with Okta.

Help

Please post any questions as comments on the blog post, or visit our Okta Developer Forums. You can also email [email protected] if would like to create a support ticket.

License

Apache 2.0, see LICENSE.

okta-spring-boot-oauth-example's People

Contributors

bdemers avatar imgbotapp avatar johngronberg-okta avatar mraible avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

okta-spring-boot-oauth-example's Issues

Typos + suggestion

Hi Matt,
gr8 tutorial. Here's some feedback:

  1. there's a typo:
    its not spring run helloGroovy.groovy its spring run helloWorld.groovy
  2. i think that would be nice to add a screenshot of what the .yaml file should look like when we added the values from the auth server metadata (see screenshot below):
    image

Okta SAML SSO for Spring Boot Web Application

Hi Team,

Am trying to integrate Okta SAML into spring boot application, plus adding authentication with using spring security.

Steps to Reproduce:

  1. Login with Okta Credentials
  2. Click on the MyApp(Created as SAML 2.0 app)
  3. It will Redirect to Single Sign On URL like (https://localhost:8443/saml/SSO)
  4. But am getting below error

java.lang.IllegalArgumentException: Invalid character found in method name. HTTP method names must be tokens

Attached is the code that i have developed, can you please help me out !

okta_saml_springboot.zip

integrated error

when I integrated okta with spring boot oauth,It response me 404 ;
https://dev-199105-admin.okta.com/error/404?fromURI=%2Foauth2%2Fdefault%2Fv1%2Fauthorize%3Fclient_id%3D0oaz4m4mcM8skClBb356%26redirect_uri%3Dhttp%3A%2F%2Flocalhost%3A8070%2Fsignin%26response_type%3Dcode%26scope%3Dopenid%2520profile%2520email%26state%3DLwup6F

image

Okta Console:
image

Spring Boot Yml :

security:
   oauth2:
      client:
         clientId: 0oaz4m4mcM8skClBb356
         clientSecret: k7m8bAAiIcDYRpEzmhcspvjSXyQRAxh-ZkCk-nuI
         accessTokenUri: https://dev-199105-admin.okta.com/oauth2/default/v1/token
         userAuthorizationUri: https://dev-199105-admin.okta.com/oauth2/default/v1/authorize
         scope: openid profile email
      sso:
         loginPath: /signin
      resource:
         userInfoUri: https://dev-199105-admin.okta.com/oauth2/default/v1/userinfo

POM:

<dependency>
 <groupId>org.springframework.security.oauth.boot</groupId>
  <artifactId>spring-security-oauth2-autoconfigure</artifactId>
  <version>2.0.0.RELEASE</version>
<dependency>

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.