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

Ғылым және технология

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

Пікірлер: 127

  • @WiliamSilvaBR
    @WiliamSilvaBR3 жыл бұрын

    This class was great! Thank you master!

  • @eclecticedge007
    @eclecticedge007 Жыл бұрын

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

  • @ahmedjimale4261
    @ahmedjimale42613 жыл бұрын

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

  • @Javatechie

    @Javatechie

    3 жыл бұрын

    Glad to hear this 😊

  • @grandselenium296
    @grandselenium296 Жыл бұрын

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

  • @manoharkota937
    @manoharkota9372 жыл бұрын

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

  • @srinivasbala8073
    @srinivasbala80734 жыл бұрын

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

  • @gourishankarmohanty2097
    @gourishankarmohanty20974 жыл бұрын

    Thanks Basant .. For OAuth2 Example.

  • @sudheerkumar-tp1mg
    @sudheerkumar-tp1mg11 ай бұрын

    Basant sir is great helping lot of IT employees

  • @samirvithlani6770
    @samirvithlani67703 жыл бұрын

    too simple explanation great sir thank you so much

  • @user-vq6yi7se2r
    @user-vq6yi7se2r3 жыл бұрын

    Great great clear explanation! Thank you Boss

  • @01cybrain
    @01cybrain2 жыл бұрын

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

  • @prithvik8448
    @prithvik8448 Жыл бұрын

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

  • @_TechWind
    @_TechWind Жыл бұрын

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

  • @Javatechie

    @Javatechie

    Жыл бұрын

    Thank you buddy 🤗

  • @-indeed8285
    @-indeed82854 жыл бұрын

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

  • @Javatechie

    @Javatechie

    4 жыл бұрын

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

  • @RiteshSingh-th9nf
    @RiteshSingh-th9nf3 жыл бұрын

    your content is awesome as always..

  • @opendeskca6333
    @opendeskca63333 жыл бұрын

    Nice explanation. Awesome!

  • @pentamnaidu
    @pentamnaidu4 жыл бұрын

    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 .

  • @Mohamed-uf5jh
    @Mohamed-uf5jh4 жыл бұрын

    Good explanation , thanks

  • @foodgallery5819
    @foodgallery5819 Жыл бұрын

    Thank you!

  • @srinig7581
    @srinig75814 жыл бұрын

    Very nice bro. Splendid job

  • @user-lw2jn8gp3e
    @user-lw2jn8gp3e9 ай бұрын

    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

  • @chandramanigupta6997
    @chandramanigupta69974 жыл бұрын

    Splendid job bro.

  • @siyedyoussef3202
    @siyedyoussef32024 жыл бұрын

    Great video Sir 👍👍👍

  • @priyagade8788
    @priyagade87883 жыл бұрын

    Thank you😊

  • @sreddy8141
    @sreddy81413 ай бұрын

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

  • @ranjandas7891
    @ranjandas78914 жыл бұрын

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

  • @raghuvaranaj1863
    @raghuvaranaj18632 жыл бұрын

    Nice explanation. Please do signout section as well.

  • @rabindrapatra7151
    @rabindrapatra71514 жыл бұрын

    simple awesome

  • @gowtham4383
    @gowtham4383 Жыл бұрын

    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 ?

  • @br4676
    @br46764 жыл бұрын

    thanks sir

  • @1msubscribers214
    @1msubscribers2144 жыл бұрын

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

  • @user-cd2qg9xe6i
    @user-cd2qg9xe6i4 ай бұрын

    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.

  • @parthanathguitar
    @parthanathguitar4 жыл бұрын

    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

    4 жыл бұрын

    Hi Prartha, I never tried , let you know soon

  • @parthanathguitar

    @parthanathguitar

    4 жыл бұрын

    Sure.. I will search for the same as well

  • @noortech254
    @noortech2543 жыл бұрын

    Amazing bhai saab😍😍

  • @ArunKumarBushigampala
    @ArunKumarBushigampala4 жыл бұрын

    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 ?

  • @vasu1297
    @vasu12973 жыл бұрын

    Nice bro

  • @smartatwork2344
    @smartatwork23444 жыл бұрын

    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

    4 жыл бұрын

    Sorry, not getting you

  • @smartatwork2344

    @smartatwork2344

    4 жыл бұрын

    @@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

    4 жыл бұрын

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

  • @sasi2182
    @sasi21824 жыл бұрын

    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??

  • @rajarajagopal7522
    @rajarajagopal75224 жыл бұрын

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

  • @Javatechie

    @Javatechie

    4 жыл бұрын

    Yes now a days max using it

  • @srinich702
    @srinich702 Жыл бұрын

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

  • @Javatechie

    @Javatechie

    Жыл бұрын

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

  • @visva2005
    @visva20053 жыл бұрын

    @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

    Жыл бұрын

    Same doubt bro

  • @Javatechie

    @Javatechie

    Жыл бұрын

    When I say client it is our application buddy.

  • @VikashGupta-wu2fc
    @VikashGupta-wu2fc Жыл бұрын

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

  • @joicejoy1331
    @joicejoy13314 жыл бұрын

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

  • @Javatechie

    @Javatechie

    4 жыл бұрын

    Implicit grant

  • @manikantanuj
    @manikantanuj3 жыл бұрын

    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

    3 жыл бұрын

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

  • @manikantanuj

    @manikantanuj

    3 жыл бұрын

    @@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.

  • @sarojsahoo8763
    @sarojsahoo87634 жыл бұрын

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

  • @RAJU9622

    @RAJU9622

    2 жыл бұрын

    No not recommended

  • @joicejoy1331
    @joicejoy13314 жыл бұрын

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

  • @Javatechie

    @Javatechie

    4 жыл бұрын

    Sorry didn't get you

  • @hemanthgarlapati2640
    @hemanthgarlapati26404 жыл бұрын

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

  • @Javatechie

    @Javatechie

    4 жыл бұрын

    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

  • @RanjeetKumar-ld7cl
    @RanjeetKumar-ld7cl3 жыл бұрын

    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.

  • @gopishettymahindra2713
    @gopishettymahindra27138 ай бұрын

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

  • @Javatechie

    @Javatechie

    8 ай бұрын

    Please check my jwt security video

  • @sandhyaaa24
    @sandhyaaa243 жыл бұрын

    Make video on jwt also ;)

  • @Javatechie

    @Javatechie

    3 жыл бұрын

    Hi sandhya , its already there in my channel here is the link kzread.info/dash/bejne/pHaCscVtqdDKYag.html

  • @bibek4024
    @bibek40243 жыл бұрын

    Nice video. Can you make a video using LinkedIn?

  • @Javatechie

    @Javatechie

    3 жыл бұрын

    Okay I will try this

  • @user-no6lb6rc5y
    @user-no6lb6rc5y4 жыл бұрын

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

  • @SmartGaming.1996
    @SmartGaming.19962 жыл бұрын

    Sir please make a video how to create own identity provider

  • @Javatechie

    @Javatechie

    2 жыл бұрын

    Yes we can do that . I will try this

  • @SmartGaming.1996

    @SmartGaming.1996

    2 жыл бұрын

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

  • @SmartGaming.1996

    @SmartGaming.1996

    2 жыл бұрын

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

  • @learncoding2752
    @learncoding27522 жыл бұрын

    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. ?

  • @Javatechie

    @Javatechie

    2 жыл бұрын

    What is the error ?

  • @rexsam3134
    @rexsam31343 жыл бұрын

    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

    3 жыл бұрын

    Wao great update let me check if there is any update

  • @rexsam3134

    @rexsam3134

    3 жыл бұрын

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

  • @SriniVasan-wk5gc
    @SriniVasan-wk5gcАй бұрын

    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

  • @ajaydhiman2368
    @ajaydhiman23685 ай бұрын

    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

    5 ай бұрын

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

  • @rishikesharora8681
    @rishikesharora86813 жыл бұрын

    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

    3 жыл бұрын

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

  • @rishikesharora8681

    @rishikesharora8681

    3 жыл бұрын

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

  • @hemalatamohanta2081
    @hemalatamohanta20814 жыл бұрын

    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

    4 жыл бұрын

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

  • @birruvijaykumar23
    @birruvijaykumar234 жыл бұрын

    Can u please do vedio on Jaeger tracing

  • @Javatechie

    @Javatechie

    4 жыл бұрын

    Hi Birru, I never tried this , let me check this

  • @birruvijaykumar23

    @birruvijaykumar23

    4 жыл бұрын

    @@Javatechie tq

  • @pankajgupta3002
    @pankajgupta3002 Жыл бұрын

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

  • @Javatechie

    @Javatechie

    Жыл бұрын

    Yes possible but need to add more configuration

  • @pankajgupta3002

    @pankajgupta3002

    Жыл бұрын

    @@Javatechie could u please make video for this

  • @Javatechie

    @Javatechie

    Жыл бұрын

    Need to check,just google it once

  • @farrukhkhan967
    @farrukhkhan9674 жыл бұрын

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

  • @sarojsahoo8763
    @sarojsahoo87634 жыл бұрын

    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

    4 жыл бұрын

    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

    2 жыл бұрын

    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
    @rexsam31343 жыл бұрын

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

  • @rexsam3134

    @rexsam3134

    3 жыл бұрын

    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"

  • @hemanthgarlapati2640
    @hemanthgarlapati26404 жыл бұрын

    Where we can see the user information after token got validated

  • @Javatechie

    @Javatechie

    4 жыл бұрын

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

  • @vengateshm2122
    @vengateshm21222 жыл бұрын

    How to do logout? Please explain.

  • @shriomtechnology1779
    @shriomtechnology17794 жыл бұрын

    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

    4 жыл бұрын

    While registering application into GitHub you will get those information

  • @shriomtechnology1779

    @shriomtechnology1779

    4 жыл бұрын

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

  • @sarojsahoo8763
    @sarojsahoo87634 жыл бұрын

    One more question Is OAuth2 is also responsible for authentication !

  • @Javatechie

    @Javatechie

    4 жыл бұрын

    Yes

  • @AnjaliMishra-gt9wk
    @AnjaliMishra-gt9wk2 жыл бұрын

    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

    2 жыл бұрын

    Please validate your callback uri

  • @gauravvishwakarma7772
    @gauravvishwakarma77723 жыл бұрын

    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

    3 жыл бұрын

    Can you please share error stack trace

  • @gauravvishwakarma7772

    @gauravvishwakarma7772

    3 жыл бұрын

    @@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

  • @sumeetyadav7141
    @sumeetyadav71413 жыл бұрын

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

  • @Javatechie

    @Javatechie

    3 жыл бұрын

    Please google it .

  • @sumeetyadav7141

    @sumeetyadav7141

    3 жыл бұрын

    @@Javatechie not got any solution

  • @deepaatekar8827
    @deepaatekar8827 Жыл бұрын

    Able to login but unable to logout

  • @Dreamriter
    @Dreamriter Жыл бұрын

    its Oauth 1 concept not Oauth 2

  • @sarojsahoo8763
    @sarojsahoo87634 жыл бұрын

    please remove ur clent id and secret from github repo

  • @bijaystha6308
    @bijaystha630811 ай бұрын

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

  • @Javatechie

    @Javatechie

    11 ай бұрын

    Yes you can store but what is the usecase

Келесі