Spring Security - OAuth2 Example Using GitHub | SpringBoot | Java Techie

Sdílet
Vložit
  • čas přidán 22. 08. 2019
  • This video explain you how to use Spring Security OAuth2 using GitHub as Resource server | Spring Boot | Spring cloud security
    #Javatechie #OAuth2 #SpringBoot
    GitHub:
    github.com/Java-Techie-jt/spr...
    Blogs:
    javagyanmantra.wixsite.com/we...
    Facebook:
    / 919464521471923
    Music: City_of_Jewels
    guys if you like this video please do subscribe now and press the bell icon to not miss any update from Java Techie
    Disclaimer/Policy:
    --------------------------------
    Note : All uploaded content in this channel is mine and its not copied from any community , you are free to use source code from above mentioned GitHub account
  • Věda a technologie

Komentáře • 127

  • @grandselenium296
    @grandselenium296 Před rokem +2

    4:16 out of all explanations I've read, this right here is the best

  • @WiliamSilvaBR
    @WiliamSilvaBR Před 4 lety +6

    This class was great! Thank you master!

  • @eclecticedge007
    @eclecticedge007 Před rokem +2

    It is crystal clear. Thank you so much! keep doing such videos.

  • @ahmedjimale4261
    @ahmedjimale4261 Před 3 lety +5

    Because of you @Java techie i passed last semester and on my way to pass this semester. Thanks a lot

  • @manoharkota937
    @manoharkota937 Před 2 lety +1

    Great session, really I got clarified all the queries in this video, thank you so much!

  • @sudheerkumar-tp1mg
    @sudheerkumar-tp1mg Před 11 měsíci +1

    Basant sir is great helping lot of IT employees

  • @01cybrain
    @01cybrain Před 2 lety +4

    Excellent explaination ., Awesome Sir !! Many Thanks !!

  • @srinivasbala8073
    @srinivasbala8073 Před 4 lety +1

    Thank You, Your explanation is nice, I understood and did a simple OAuth application

  • @gourishankarmohanty2097
    @gourishankarmohanty2097 Před 4 lety +1

    Thanks Basant ..
    For OAuth2 Example.

  • @user-vq6yi7se2r
    @user-vq6yi7se2r Před 3 lety +1

    Great great clear explanation! Thank you Boss

  • @samirvithlani6770
    @samirvithlani6770 Před 4 lety +1

    too simple explanation great sir thank you so much

  • @-indeed8285
    @-indeed8285 Před 4 lety +2

    Amazing..
    You explanation is to the point.. Like that.. 👍
    I hope you upload new video regularly. 💙

    • @Javatechie
      @Javatechie  Před 4 lety +1

      Thank you Mohammad +
      Yes will continue upload on every weekend 👍

  • @RiteshSingh-th9nf
    @RiteshSingh-th9nf Před 3 lety +1

    your content is awesome as always..

  • @_TechWind
    @_TechWind Před rokem +1

    if i want to know any concept i always prefer your channel 👍. the way you explain is good, it helps too

  • @srinig7581
    @srinig7581 Před 4 lety +1

    Very nice bro. Splendid job

  • @opendeskca6333
    @opendeskca6333 Před 3 lety +1

    Nice explanation. Awesome!

  • @ranjandas7891
    @ranjandas7891 Před 4 lety +2

    Nice explanation Sir..keep it up(This is Ranjan Das from Facebook😛)

  • @chandramanigupta6997
    @chandramanigupta6997 Před 4 lety +1

    Splendid job bro.

  • @Mohamed-uf5jh
    @Mohamed-uf5jh Před 4 lety +1

    Good explanation , thanks

  • @prithvik8448
    @prithvik8448 Před rokem +4

    No one can explained like this. Great job very clean 👌 I got both theoritical and practical knowledge

  • @siyedyoussef3202
    @siyedyoussef3202 Před 4 lety +1

    Great video Sir 👍👍👍

  • @raghuvaranaj1863
    @raghuvaranaj1863 Před 2 lety +1

    Nice explanation. Please do signout section as well.

  • @foodgallery5819
    @foodgallery5819 Před rokem +1

    Thank you!

  • @priyagade8788
    @priyagade8788 Před 3 lety +1

    Thank you😊

  • @rabindrapatra7151
    @rabindrapatra7151 Před 4 lety

    simple awesome

  • @noortech254
    @noortech254 Před 3 lety

    Amazing bhai saab😍😍

  • @br4676
    @br4676 Před 4 lety +1

    thanks sir

  • @pentamnaidu
    @pentamnaidu Před 4 lety

    We can also do single sign on / security by passing using spring security right (http basic authentication) from one application to another by skipping actual login page /screen .

  • @user-lw2jn8gp3e
    @user-lw2jn8gp3e Před 10 měsíci

    awesome demonstration sir, , kindly do the same okta with the Spring Boot 3 version , the older version not working properly, all the time got bad requests

  • @vasu1297
    @vasu1297 Před 3 lety +1

    Nice bro

  • @sreddy8141
    @sreddy8141 Před 4 měsíci

    Thanks Sir🙂 Helped me to understand.
    How authorization server generates token and resource server validates the same, could you please explain sir

  • @ArunKumarBushigampala
    @ArunKumarBushigampala Před 4 lety +1

    Hi.. As per the flow diagram after successful authentication only authorization server sends access token right? then how come access token send as cookie in login page before authentication ?

  • @rajarajagopal7522
    @rajarajagopal7522 Před 4 lety +1

    Very Good Explanation Basant.. so I guess most of company web applications are using OAuth token security only. Correct?

  • @bibek4024
    @bibek4024 Před 3 lety +2

    Nice video. Can you make a video using LinkedIn?

  • @gowtham4383
    @gowtham4383 Před rokem +1

    Hi bro , This video is really good about Oauth. Having some doubt on this, In the example we registered the local host app to Git hub as an oauth App and client id and client secret key generated.
    But in real time example Hacker rank with Git Hub login , Hacker rank registered as oauth app automatically post successful github login . How does it happen internally ? Can you explain the code for that ?

  • @sasi2182
    @sasi2182 Před 4 lety

    I have one doubt,
    In this example we put our clent id and secrt id in our appliaction, which was taken from our git hub,
    1)But real time like haker rank we cant put mannually right,??
    2) as per my assumption after validating username and password, doest github gave cleint id and scrt id return back to appliacation after succussfull login??
    I have these doubt from so many days??
    If in that case what we need to put in our yml file??

  • @smartatwork2344
    @smartatwork2344 Před 4 lety +1

    Hy, 'Java Techie' linke Tour explanations. Very clear and understandable. One question: What"s the Authentication-Code? Is this a random Nummer choosen by yourself? Thx, bye.

    • @Javatechie
      @Javatechie  Před 4 lety

      Sorry, not getting you

    • @smartatwork2344
      @smartatwork2344 Před 4 lety +1

      @@Javatechie Sorry, wrong typing. I like your Explanation. When you typed in your Authentication, you also typed in a Number in the field Authentication-Code. Where you where getting this number?

    • @Javatechie
      @Javatechie  Před 4 lety

      @@smartatwork2344 I enable two factor authentication so I got OTP to email so am using that number

  • @1msubscribers214
    @1msubscribers214 Před 4 lety

    It means each user will add the Clinet application details in their githup profile.... Dynamically how to do sir..
    Thanks for ur effort...

  • @parthanathguitar
    @parthanathguitar Před 4 lety +1

    Hello. Very nice example. I have a question. I can see that the client I'd and secret string is directly configured in the spring boot app and that only helps an individual user to be authenticated by Github authorization server. What happens in a real time production grade project? Do we decouple this sensitive information and store it somewhere else. And what configuration we need to make if we want to access the restful api created in this example to be accessed by any user having valid github credential. I hope there is a way to dynamically use the users client I'd and secret key in the spring boot configuration

    • @Javatechie
      @Javatechie  Před 4 lety

      Hi Prartha, I never tried , let you know soon

    • @parthanathguitar
      @parthanathguitar Před 4 lety

      Sure.. I will search for the same as well

  • @srinich702
    @srinich702 Před rokem +1

    Can you please do one session on two or more microservices with oauth2

    • @Javatechie
      @Javatechie  Před rokem

      Yes I will do that.since maximum viewers requested for the same It's in queue

  • @user-cd2qg9xe6i
    @user-cd2qg9xe6i Před 4 měsíci

    Hi @java Techie if possible can u please upload the video for how the Token is generated and what we need to use for encryption and decryption logic in which class need to write and give access.

  • @sandhyaaa24
    @sandhyaaa24 Před 3 lety +1

    Make video on jwt also ;)

    • @Javatechie
      @Javatechie  Před 3 lety +1

      Hi sandhya , its already there in my channel here is the link czcams.com/video/rBNOc4ymd1E/video.html

  • @ajaydhiman2368
    @ajaydhiman2368 Před 6 měsíci +1

    another question : why you added client security dependency ? spring security dependecncy will not work ? or we really need any of these dependency to create this application ?

    • @Javatechie
      @Javatechie  Před 6 měsíci +1

      You need oauth2 client dependency to delegate your security concern to a 3rd party identity provider (GitHub/ Facebook / Gmail etc...)

  • @joicejoy1331
    @joicejoy1331 Před 4 lety +2

    What is the authorization grant type used, authorization_code or implicit grant?

  • @visva2005
    @visva2005 Před 3 lety +1

    @video 13.32 you mentioned that Access Token is sent from client . Could you please explain how the client generated access token ? Because we had configured only the Client Secret in the yml file.

    • @sais7065
      @sais7065 Před rokem +1

      Same doubt bro

    • @Javatechie
      @Javatechie  Před rokem

      When I say client it is our application buddy.

  • @hemanthgarlapati2640
    @hemanthgarlapati2640 Před 4 lety +2

    What is the need of sending back the access token to github resource server which was given by github itself

    • @Javatechie
      @Javatechie  Před 4 lety +1

      GitHub authorization server will send access token , how resource server will verify already you authorized it ?
      That's the reason access token should be 2 way

  • @joicejoy1331
    @joicejoy1331 Před 4 lety +2

    How come the access token in the cookie before sign in to the GitHub account...while you were inspecting the elements

  • @sarojsahoo8763
    @sarojsahoo8763 Před 4 lety +2

    Is it recommended to use in a real time Application I mean there is no secrecy of client id and client secret

  • @SmartGaming.1996
    @SmartGaming.1996 Před 2 lety +1

    Sir please make a video how to create own identity provider

    • @Javatechie
      @Javatechie  Před 2 lety +1

      Yes we can do that . I will try this

    • @SmartGaming.1996
      @SmartGaming.1996 Před 2 lety

      Ok sir please create video as soon as possible because I want to implement it in a practical way

    • @SmartGaming.1996
      @SmartGaming.1996 Před 2 lety

      @@Javatechie Sir please make a video how to create own identity provider

  • @rexsam3134
    @rexsam3134 Před 3 lety +1

    Hi Basant.
    Spring Boot just got updated to 2.3.4
    Inspite of logging out of Github, why is it not asking for the credentials for the next subsequent login when I type the same url on another chrome tab? I dont want to restart the app

    • @Javatechie
      @Javatechie  Před 3 lety

      Wao great update let me check if there is any update

    • @rexsam3134
      @rexsam3134 Před 3 lety +1

      @@Javatechie Yes I found the Tomcat jars are new as compared to the 2.3.3 version

  • @learncoding2752
    @learncoding2752 Před 2 lety +1

    I am trying spring version 2.6.1 and even maven update.. i am unable to get resolved, kindly guide should i change to as you mentioned and or go with that. ?

  • @RanjeetKumar-ld7cl
    @RanjeetKumar-ld7cl Před 3 lety

    HI Basant
    I am getting below error after login
    ava.lang.IllegalStateException: Access token provider returned a null access token, which is illegal according to the contract.

  • @VikashGupta-wu2fc
    @VikashGupta-wu2fc Před rokem

    Could you guide how to cret a spring boot oauth 2 with keycloak for multitenant?

  • @manikantanuj
    @manikantanuj Před 3 lety +1

    Your way of teaching is awesome.
    I need a help, Actually I want to consume the services of Adobe analytics. I have retrieved all the essential data required but I am confused what to put in "security.oauth2.resource.user-info-uri" property. When I start my server then I am able to login but it stuck on that page only. Can you please help!

    • @Javatechie
      @Javatechie  Před 3 lety +1

      What third part you are using for SSO ?
      Is it same GitHub ?

    • @manikantanuj
      @manikantanuj Před 3 lety

      @@Javatechie I am trying to fetch the data of Adobe Analytics using API and trying to get it authorized by Oauth2.0.
      So in Application.properties what should be written under security.oauth2.resource.user-info-uri.

  • @hemalatamohanta2081
    @hemalatamohanta2081 Před 4 lety +1

    I tried this one ,successfully run application ,and getting login page but login by giving credentials getting error page "site can not be reached ".in application logs are also fine so not able to check exactly why i am getting error.Could you please guiding me on this.

    • @Javatechie
      @Javatechie  Před 4 lety

      Are you getting GitHub login page right ? If yes then please provide your GitHub credential to login

  • @gopishettymahindra2713
    @gopishettymahindra2713 Před 9 měsíci +1

    Hi sir, Can you please explain one post request through postman how you will pass authentication information in the header.

    • @Javatechie
      @Javatechie  Před 9 měsíci

      Please check my jwt security video

  • @birruvijaykumar23
    @birruvijaykumar23 Před 4 lety +1

    Can u please do vedio on Jaeger tracing

  • @AnjaliMishra-gt9wk
    @AnjaliMishra-gt9wk Před 2 lety +1

    i am getting this error :
    error: redirect_uri_mismatch
    error_description: The redirect_uri MUST match the registered callback URL for this application.
    Please help, even though done same :/

    • @Javatechie
      @Javatechie  Před 2 lety +1

      Please validate your callback uri

  • @user-no6lb6rc5y
    @user-no6lb6rc5y Před 4 lety

    i think access token should not deliver by browser which should pass in the backend

  • @sumeetyadav7141
    @sumeetyadav7141 Před 3 lety +1

    I am getting a error --- field error in object 'resourceServerProperties' on field 'tokenInfoUri': rejected value [null]; missing.tokenInfoUri.resourceServerProperties.tokenInfoUri
    Please help me out

  • @hemanthgarlapati2640
    @hemanthgarlapati2640 Před 4 lety +1

    Where we can see the user information after token got validated

    • @Javatechie
      @Javatechie  Před 4 lety +1

      You can't see user information GitHub resource server will send to client based on your permission .

  • @shriomtechnology1779
    @shriomtechnology1779 Před 4 lety +1

    where you get this below url's.-
    accessTokenUri, userAuthorizationUri, userInfoUri. if i want to the same OAuth authentication for FB or any other authorization portal. where i can get this url's.

    • @Javatechie
      @Javatechie  Před 4 lety

      While registering application into GitHub you will get those information

    • @shriomtechnology1779
      @shriomtechnology1779 Před 4 lety +1

      Thank you very much 😊. Very quick response. Nice explanation 👍

  • @SriniVasan-wk5gc
    @SriniVasan-wk5gc Před 2 měsíci

    Hi Sir , needed the updated procedure of Spring security with OAuth2,ssince cloud security ,cloud Outh dependencies are not shown under dependencies of spring initializer,sir

  • @gauravvishwakarma7772
    @gauravvishwakarma7772 Před 3 lety +1

    after giving GitHub login credentials, i got page mentioned - you are redirect to authorised application, if your browser does support, click here,
    after click it is downloaded not further process failed

    • @Javatechie
      @Javatechie  Před 3 lety

      Can you please share error stack trace

    • @gauravvishwakarma7772
      @gauravvishwakarma7772 Před 3 lety

      @@Javatechie
      thank u for reply
      You are being redirected to the authorized application.
      If your browser does not redirect you back, please click here to continue.
      after clicking on 'click here' is get downloaded

  • @farrukhkhan967
    @farrukhkhan967 Před 4 lety

    How do we know if we are using 2 legged or 3 legged ?

  • @pankajgupta3002
    @pankajgupta3002 Před rokem +1

    Great session , but i want same session with Spring MVC , is it possible ?

    • @Javatechie
      @Javatechie  Před rokem +1

      Yes possible but need to add more configuration

    • @pankajgupta3002
      @pankajgupta3002 Před rokem +1

      @@Javatechie could u please make video for this

    • @Javatechie
      @Javatechie  Před rokem

      Need to check,just google it once

  • @sarojsahoo8763
    @sarojsahoo8763 Před 4 lety +1

    One more question Is OAuth2 is also responsible for authentication !

  • @rishikesharora8681
    @rishikesharora8681 Před 3 lety +2

    HI Basant,
    I really appreciate your effort, i learnt a lot regarding OAuth2, and mostly asked question in the interview.
    I tried your example, but it is giving me below exception, tried finding out from StackOverFlow, but no luck, Will you please give any hint or help?
    java.lang.IllegalStateException: Access token provider returned a null access token, which is illegal according to the contract.

    • @Javatechie
      @Javatechie  Před 3 lety +1

      Did you add your own access token as I shown in video how to generate

    • @rishikesharora8681
      @rishikesharora8681 Před 3 lety +1

      @@Javatechie Thanks a lot for your quick response, it has been fixed after watching your comment...Thank a lot again 😍

  • @sarojsahoo8763
    @sarojsahoo8763 Před 4 lety

    How the access token is getting generated by Authorization server and How Resource server is validating whether it is a correct access_token or not!

    • @Javatechie
      @Javatechie  Před 4 lety

      Saroj I inspected the console if you notice while sending request it will send token as part of request header if it is not valid you will get 403 status code else 200
      You can also do same just inspect your browser while sending first request

    • @RAJU9622
      @RAJU9622 Před 2 lety

      Saroj actually , before launching the page there will be one more call to git hub to give the access token, that access token given by github because application is sending in the request client if and secret , as it’s matching with the git oauth2 credentials so only git hub authenticated and given the access token. If you want to test give wrong secret I will never get back the access token and u r not able to login I will get 403 error as Basant said. Let me know if need more information or anything confusion.

  • @rexsam3134
    @rexsam3134 Před 3 lety

    Pls Zoom in your screen.
    Please explain the yml configuration parameters added
    Boot 2.4.1 doest have Spring Cloud Security enabled

    • @rexsam3134
      @rexsam3134 Před 3 lety

      2.1.4 is no longer supported in STS 4 and gives ClassNotFoundException
      2.3.7 gives
      "message": "Not Found",
      "documentation_url": "docs.github.com/rest"

  • @vengateshm2122
    @vengateshm2122 Před 2 lety

    How to do logout? Please explain.

  • @deepaatekar8827
    @deepaatekar8827 Před rokem

    Able to login but unable to logout

  • @Dreamriter
    @Dreamriter Před rokem

    its Oauth 1 concept not Oauth 2

  • @sarojsahoo8763
    @sarojsahoo8763 Před 4 lety

    please remove ur clent id and secret from github repo

  • @bijaystha6308
    @bijaystha6308 Před 11 měsíci +1

    Hello,
    will the information (emails) be stored in local database?

    • @Javatechie
      @Javatechie  Před 11 měsíci

      Yes you can store but what is the usecase