OAuth2 mit Spring boot und Java

Husker

Mitglied
Hallo ich versuche Aktuell eine REST API zu erstellen, ich hatte es erst über Swagger versucht, musst aber feststellen das die JAVA Implementation von Swagger noch nicht wirklich gut ist, gehopst wie gesprungen, also habe ich versucht das mit Spring Boot zu machen.

das Erste Beispiel aus Basis dieser Seite:
https://gigsterous.github.io/engineering/2017/03/01/spring-boot-4.html
lief auch erstmal super, das Beispiel lief und machte das was ich wollte. Soweit so gut, also habe ich versucht das Beispiel zu in meinem eigenen Projekt nach zubauen, auch das lief soweit erst mal gut, leider ist es so das ich mich an der API nicht anmelden kann.

ich bekomme immer wieder die meldung:
{"timestamp":1514905794221,"status":401,"error":"Unauthorized","message":"Bad credentials","path":"/Api/oauth/token"}

erst dachte ich das er aus irgendwelche Gründen den Benutzer nicht sauber aus der DB laden kann, oder das Passwort nicht oder Falsch gehasht wird oder sowas in die richtung, allerdings scheint das hier nicht der fall zu sein, nach dem ich das Logging auf debug gestellt hatte bekomme ich jetzt auch ausführlicherere Information

logauszug:
2018-01-02 16:09:53.915 DEBUG 25056 --- [qtp561480862-19] o.s.s.w.u.matcher.AntPathRequestMatcher : Request 'POST /oauth/token' doesn't match 'DELETE /logout
2018-01-02 16:09:53.921 DEBUG 25056 --- [qtp561480862-19] o.s.s.web.util.matcher.OrRequestMatcher : No matches found
2018-01-02 16:09:53.921 DEBUG 25056 --- [qtp561480862-19] o.s.security.web.FilterChainProxy : /oauth/token at position 5 of 11 in additional filter chain; firing Filter: 'BasicAuthenticationFilter'
2018-01-02 16:09:53.928 DEBUG 25056 --- [qtp561480862-19] o.s.s.w.a.www.BasicAuthenticationFilter : Basic Authentication Authorization header found for user 'builttapi'
2018-01-02 16:09:53.932 DEBUG 25056 --- [qtp561480862-19] o.s.s.authentication.ProviderManager : Authentication attempt using org.springframework.security.authentication.dao.DaoAuthenticationProvider
2018-01-02 16:09:53.956 DEBUG 25056 --- [qtp561480862-19] o.s.s.a.dao.DaoAuthenticationProvider : User 'testuser' not found
2018-01-02 16:09:53.970 DEBUG 25056 --- [qtp561480862-19] o.s.b.f.s.DefaultListableBeanFactory : Returning cached instance of singleton bean 'authenticationAuditListener'
2018-01-02 16:09:53.971 DEBUG 25056 --- [qtp561480862-19] o.s.b.f.s.DefaultListableBeanFactory : Returning cached instance of singleton bean 'delegatingApplicationListener'
2018-01-02 16:09:53.980 DEBUG 25056 --- [qtp561480862-19] o.s.b.f.s.DefaultListableBeanFactory : Returning cached instance of singleton bean 'auditListener'
2018-01-02 16:09:53.981 DEBUG 25056 --- [qtp561480862-19] o.s.b.f.s.DefaultListableBeanFactory : Returning cached instance of singleton bean 'delegatingApplicationListener'
2018-01-02 16:09:53.982 DEBUG 25056 --- [qtp561480862-19] o.s.b.a.audit.listener.AuditListener : AuditEvent [timestamp=Tue Jan 02 16:09:53 CET 2018, principal=testuser, type=AUTHENTICATION_FAILURE, data={details=org.springframework.security.web.authentication.WebAuthenticationDetails@957e: RemoteIpAddress: 127.0.0.1; SessionId: null, type=org.springframework.security.authentication.BadCredentialsException, message=Bad credentials}]
2018-01-02 16:09:53.984 DEBUG 25056 --- [qtp561480862-19] o.s.s.w.a.www.BasicAuthenticationFilter : Authentication request for failed: org.springframework.security.authentication.BadCredentialsException: Bad credentials

vor allem aber dieses Zeile lässt mich etwas stuzen:
2018-01-02 16:09:53.956 DEBUG 25056 --- [qtp561480862-19] o.s.s.a.dao.DaoAuthenticationProvider : User 'testuser' not found

der entsprechende JAVA Code dazu:
[OAuth2Config.java]
Java:
    @Override
    public void configure(ClientDetailsServiceConfigurer clients) throws Exception
    {
        logger.info("Config Client ... .. .");
        clients.inMemory().withClient("testuser").secret("secret").accessTokenValiditySeconds(expiration)
                .scopes("read", "write").authorizedGrantTypes("password", "refresh_token")
                .resourceIds("resource");
    }

als erstes muss ich erstmal zugeben, das ich diesen Teil des Codes nicht wirklich verstehe, scheinbar wird hier ein zusätzlicher Benutzer und Passwort Benutzt, warum weiss ich nicht, es stammt aus dem Beispiel und Funktioniert in diesem auch nur nicht bei mir und daraus ergeben Sich auch ein oder zwei Fragen:


hier erst ein mal noch die Komplette Klasse:
Java:
package com.webservice.config;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.authentication.AuthenticationManager;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.security.oauth2.config.annotation.configurers.ClientDetailsServiceConfigurer;
import org.springframework.security.oauth2.config.annotation.web.configuration.AuthorizationServerConfigurerAdapter;
import org.springframework.security.oauth2.config.annotation.web.configuration.EnableAuthorizationServer;
import org.springframework.security.oauth2.config.annotation.web.configurers.AuthorizationServerEndpointsConfigurer;

import com.webservice.ApiApplication;

@Configuration
@EnableAuthorizationServer
public class OAuth2Config extends AuthorizationServerConfigurerAdapter
{

    private static final Logger logger = LoggerFactory.getLogger(OAuth2Config.class);
   
    @Autowired
    @Qualifier("userDetailsService")
    private UserDetailsService userDetailsService;

    @Autowired
    private AuthenticationManager authenticationManager;

    @Value("${webservice.oauth.tokenTimeout:3600}")
    private int expiration;

    // password encryptor
    @Bean
    public PasswordEncoder passwordEncoder()
    {
        logger.info("Create Password Encoder ... .. .");
        return new BCryptPasswordEncoder();
    }

    @Override
    public void configure(AuthorizationServerEndpointsConfigurer configurer) throws Exception
    {
        logger.info("Set OAuth Config ... .. .");
        configurer.authenticationManager(authenticationManager);
        configurer.userDetailsService(userDetailsService);
    }

    @Override
    public void configure(ClientDetailsServiceConfigurer clients) throws Exception
    {
        logger.info("Config Client ... .. .");
        clients.inMemory().withClient("testuser").secret("secret").accessTokenValiditySeconds(expiration)
                .scopes("read", "write").authorizedGrantTypes("password", "refresh_token")
                .resourceIds("resource");
    }

}

Sooooo:
  1. wofür brauche ich einen 2ten Benutzername und Passwort?
  2. wo werden diese Gespeichert?
  3. ist das so überhaupt sinvoll ?
solangsam weiss ich leider nicht mehr weiter, mir fehlt hier zugegeben auch ein wenig hintergrundwissen, aber ich finde auch nicht wirklich gute Literatur die diesesn Part beschreibt.

kann mir jemand Helfen?
 

truesoul

Top Contributor
Hallo.

Den Teil:

Java:
clients.inMemory().withClient("testuser").secret("secret").accessTokenValiditySeconds(expiration)
                .scopes("read", "write").authorizedGrantTypes("password", "refresh_token")
                .resourceIds("resource");

solltest du nicht mehr benötigen. Ansonsten kann man nicht viel dazu sagen, da Informationen fehlen.
Wie sieht deine Web Security Configuration aus?
Verwendest du GenericFilterBean?

Den Link den du gepostet hast, ist zu dünn um tatsächlich eine sinnvolle Authentifizierung zu implementieren.

Vielleicht schaust du dir das mal an.

Ich würde vermuten, dass die Web Security Configuration nicht korrekt ist.

Grüße
 

truesoul

Top Contributor
Schaue dir einfach mal den link an den ich gepostet hatte. Achja, Swagger ist nicht das selbe wie Spring Boot. Und meine Erfahrungen mit Swagger waren eigentlich recht gut. Swagger dient ja dazu deine Schnittstellen auch zu beschreiben und zu dokumentieren.

Also eigentlich ziemlich cool.

Grüße
 

Husker

Mitglied
Ja das mit Swagger habe ich auch durch, als ich drauf gestoßen bin dachte ich mir, wie geil !
dan habe ich angefangen und musste feststellen das Swagger keine Implementierung für API Key OAuth usw. in java hat, es wurde einfach nicht implementiert, gibt dazu auch aktuell ein Issue bei GIT also kommen die Securty definitionen im Code nicht an, soviel erstmal zu swagger, das war auch der Grund warum ich Swagger erstmal zur seite geschoben habe und mir dachte gut, braust du deine REST API mit Spring Boot, und das ausprobieren des Beispiels war erst mal super vielversprechend aber ich bekomme es einfach nicht ans laufen.

bin aktuell dabei mir den Link anzusehen aber so wirklich schlau werde ich daraus nicht
eigentlich sollte es doch keine Riesen sache sein eine REST API mir OAuth zu bauen, aber scheinbar bin ich dafür irgendwie zu doof (Bin da Aktuell etwas Deprimiert)

werde erst mal weiter versuchen den Link von dir durch zu arbeiten aber leider ist die Doku irgendwie ziemlich dünn
 

Husker

Mitglied
So in zwischen habe ich das ans laufen bekommen, ich weiss nur noch nicht genau warum,
habe das Projekt letzt entlich weggeworfen und stück für stück neu aufgebaut, läuft jetzt aber und mit Spring-Fox läuft jetzt auch swagger :)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
sascha-sphw Spring Boot Resource Server (OAuth2) @MockMvc Frameworks - Spring, Play, Blade, Vaadin & Co 5
H Spring Boot, Hibernate und OAuth2 wie komme ich an den User? Frameworks - Spring, Play, Blade, Vaadin & Co 13
S Spring Security mit oauth2 in lokaler Konfiguration principal mocken Frameworks - Spring, Play, Blade, Vaadin & Co 0
8u3631984 Ist es möglich in Spring Entity generische Listen verwenden Frameworks - Spring, Play, Blade, Vaadin & Co 3
R Spring Boot Test Assertions mit Objekten Frameworks - Spring, Play, Blade, Vaadin & Co 6
8u3631984 Pfad zu Test Datei in application.yml in Spring Boot Test Frameworks - Spring, Play, Blade, Vaadin & Co 7
R Spring Boot sql Beziehungen Frameworks - Spring, Play, Blade, Vaadin & Co 12
8u3631984 Spring JPA Probleme beim SPeichern von Sets Frameworks - Spring, Play, Blade, Vaadin & Co 3
M Spring Boot 3 Datenbanken zur Laufzeit Verbinden Frameworks - Spring, Play, Blade, Vaadin & Co 5
8u3631984 Spring JDBC Probleme beim Spaltennamen Frameworks - Spring, Play, Blade, Vaadin & Co 3
LimDul Spring-Batches in Docker über Rest starten/verfolgen Frameworks - Spring, Play, Blade, Vaadin & Co 0
ExceptionOfExpectation In Meiner Spring-Boot Applikation verlangt die Datenbank Wert für eine ID Frameworks - Spring, Play, Blade, Vaadin & Co 5
H Spring Boot Applikation und JHM Benchmark sowie ContextConfiguration in H2 Tests ich bekomme es nicht hin Frameworks - Spring, Play, Blade, Vaadin & Co 2
ExceptionOfExpectation Tests in Spring-Boot Frameworks - Spring, Play, Blade, Vaadin & Co 4
R Eure Erfahrungen mit Primefaces und Spring - wer managed die Beans Frameworks - Spring, Play, Blade, Vaadin & Co 4
Avalon Get Request doppelt abfeuern ohne Post Redirect Get Pattern. Spring Boot Thymeleaf MVC Frameworks - Spring, Play, Blade, Vaadin & Co 12
thor_norsk Konfigurationsprobleme mit Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 9
R Spring Boot Integration-testing mit Keycloak Frameworks - Spring, Play, Blade, Vaadin & Co 1
R Spring Boot Integration-testing mit Keycloak Frameworks - Spring, Play, Blade, Vaadin & Co 13
L Spring Data und Rest Controller? Frameworks - Spring, Play, Blade, Vaadin & Co 4
thor_norsk Spring Boot Fehler Frameworks - Spring, Play, Blade, Vaadin & Co 1
L Spring Data und Rest Conroller? Frameworks - Spring, Play, Blade, Vaadin & Co 4
thor_norsk Spring Boot und Docker Frameworks - Spring, Play, Blade, Vaadin & Co 5
B Spring Amazon-SP-Api Frameworks - Spring, Play, Blade, Vaadin & Co 3
8u3631984 Aktualisiere Spring Controller Frameworks - Spring, Play, Blade, Vaadin & Co 4
L Spring Data: Modellierung mit einer Embeddable bean Frameworks - Spring, Play, Blade, Vaadin & Co 2
D Spring Boot Test ob Validation geprüft wurde Frameworks - Spring, Play, Blade, Vaadin & Co 8
K Spring Boot OneToMany Frameworks - Spring, Play, Blade, Vaadin & Co 6
8u3631984 Spring Boot Docker Image erstellen und mit docker-compose konfigurieren Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Wann Spring Batch nutzen? Frameworks - Spring, Play, Blade, Vaadin & Co 1
P Spring Hessian Remote Beispiel Frameworks - Spring, Play, Blade, Vaadin & Co 20
8u3631984 Spring 2.7.8 Info Enpoint nicht zuerreichen Frameworks - Spring, Play, Blade, Vaadin & Co 1
gradlew.bat spring-boot:run funktioniert nicht Frameworks - Spring, Play, Blade, Vaadin & Co 4
Zrebna Spring Boot/Thymeleaf: Bestätigungsemail senden. Frameworks - Spring, Play, Blade, Vaadin & Co 2
Zrebna Spring - Thymeleaf: Wieso wird gem. Fallunterscheidung entsprechende View nicht geladen? Frameworks - Spring, Play, Blade, Vaadin & Co 3
Dimax Spring UsernameNotFoundException(msg); auf der View msg ausdrücken Frameworks - Spring, Play, Blade, Vaadin & Co 1
Dimax Spring UsernameNotFoundException(Message) auf der View Message ausdrücken Frameworks - Spring, Play, Blade, Vaadin & Co 2
B Spring Boot und JPA Error creating bean Frameworks - Spring, Play, Blade, Vaadin & Co 24
R Spring Security: Wie kommt 'UserDetails' an Username und Passwort ran? Frameworks - Spring, Play, Blade, Vaadin & Co 6
R Spring Security: Wie den User dynamisch authentifizieren? Frameworks - Spring, Play, Blade, Vaadin & Co 8
R Spring Security: Authentication & Permissions Frameworks - Spring, Play, Blade, Vaadin & Co 4
R Spring Boot: Warum soll PasswordEncoder in einer neuen Methode definiert sein? Frameworks - Spring, Play, Blade, Vaadin & Co 1
8u3631984 Cross-Origin beim Abrufen von Spring Endpoint Frameworks - Spring, Play, Blade, Vaadin & Co 1
D Spring Boot und Microservices Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Boot additional Datasource for a single entity Frameworks - Spring, Play, Blade, Vaadin & Co 0
T Spring Resourcen Ordner ermitteln Frameworks - Spring, Play, Blade, Vaadin & Co 5
B Spring JPA und Repository Frameworks - Spring, Play, Blade, Vaadin & Co 12
D Mapstruct Dependency Injection funktioniert nicht mit Spring Frameworks - Spring, Play, Blade, Vaadin & Co 15
Avalon Wie sieht bei Euch das Deployment einer Spring Boot Anwendung aus? Frameworks - Spring, Play, Blade, Vaadin & Co 4
M Threads in Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 7
W DI-Problem in Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 4
T Spring Boot: Was bewirkt parent in maven genau? Frameworks - Spring, Play, Blade, Vaadin & Co 4
T Spring Security: Run-as replacement Einsatzbereich? Frameworks - Spring, Play, Blade, Vaadin & Co 1
OnDemand Vaadin+Spring Boot erster Seitenload nach Neustart endlos Frameworks - Spring, Play, Blade, Vaadin & Co 0
doncarlito87 Wie erhalte ich ein JSON aus eine NativeQuery (Spring Boot)? Frameworks - Spring, Play, Blade, Vaadin & Co 8
Avalon @Query Select Abfrage liefert falsche Werte (Spring Boot, JPA, Hibernate) Frameworks - Spring, Play, Blade, Vaadin & Co 3
Avalon Erstellung Dockerimage mit spring-boot:build-image in Spring Boot mit Umgebungsvariablen Frameworks - Spring, Play, Blade, Vaadin & Co 0
N Spring Integration - Logging Frameworks - Spring, Play, Blade, Vaadin & Co 7
D Spring Boot Field Injection in MapStruct Frameworks - Spring, Play, Blade, Vaadin & Co 5
D Spring Anfänger benötigt Hilfe Frameworks - Spring, Play, Blade, Vaadin & Co 9
OnDemand Spring Boot seltsame Logeinträge: Manipulationsversuche? Frameworks - Spring, Play, Blade, Vaadin & Co 2
D Spring Date keine neue Tabelle fuer Attribut Frameworks - Spring, Play, Blade, Vaadin & Co 1
T Spring Security Config File anpassen Frameworks - Spring, Play, Blade, Vaadin & Co 1
8u3631984 Spring Cloud : Resttemplate mit Loadballancer Frameworks - Spring, Play, Blade, Vaadin & Co 11
Dimax Spring resource not found Frameworks - Spring, Play, Blade, Vaadin & Co 2
M Spring MongoDB unique index Frameworks - Spring, Play, Blade, Vaadin & Co 3
M Spring Entity testen Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Entity testen Frameworks - Spring, Play, Blade, Vaadin & Co 5
Dimax Spring App Probleme beim Ausführen auf dem Tomcat Server Frameworks - Spring, Play, Blade, Vaadin & Co 1
D Spring WebFlux Cors konfigurieren Frameworks - Spring, Play, Blade, Vaadin & Co 1
Dimax Schöne View mit anchor scrolling in Spring Frameworks - Spring, Play, Blade, Vaadin & Co 2
Dimax Spring JPA Multiple Keys Frameworks - Spring, Play, Blade, Vaadin & Co 3
D Spring Boot Mile Stone und Snapshot Versionen Frameworks - Spring, Play, Blade, Vaadin & Co 2
OnDemand Spring Boot Exception Body Frameworks - Spring, Play, Blade, Vaadin & Co 2
D Was ist das Framework "Spring"? Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Unit/Integrations Testing Frameworks - Spring, Play, Blade, Vaadin & Co 3
D Spring Unit Test: UnsatisfiedDependencyException: Error creating bean with name Frameworks - Spring, Play, Blade, Vaadin & Co 2
H Resource Liste Lazy Autowired Spring Context Frameworks - Spring, Play, Blade, Vaadin & Co 2
M Java Spring Security Frameworks - Spring, Play, Blade, Vaadin & Co 5
M Spring Security Login with Credentials Frameworks - Spring, Play, Blade, Vaadin & Co 0
N Spring Boot - Overkill für private Projekte? Frameworks - Spring, Play, Blade, Vaadin & Co 3
krgewb Spring und GWT - & wird zu & amp; Frameworks - Spring, Play, Blade, Vaadin & Co 2
K Migration eines internen Frameworks zu Spring:Boot Frameworks - Spring, Play, Blade, Vaadin & Co 0
OnDemand JPA/Spring Repository Like Suche leeres Ergebnis Frameworks - Spring, Play, Blade, Vaadin & Co 0
Z Hibernate & Postgres in Spring Boot (Syntaxprobleme) Frameworks - Spring, Play, Blade, Vaadin & Co 2
Z Spring Boot mit JPA;, Hibernate, Rest & Lombok Frameworks - Spring, Play, Blade, Vaadin & Co 8
M Spring Initializer - Webservices Frameworks - Spring, Play, Blade, Vaadin & Co 0
D Spring Hateoas Frameworks - Spring, Play, Blade, Vaadin & Co 1
ma095 Spring und Postgresql Errors Frameworks - Spring, Play, Blade, Vaadin & Co 4
OnDemand Spring+Vaadin App startet nicht Frameworks - Spring, Play, Blade, Vaadin & Co 1
OnDemand Spring Request externe API SSL Error Frameworks - Spring, Play, Blade, Vaadin & Co 7
OnDemand Spring Repo speichert, aber es kommt in der DB nicht an Frameworks - Spring, Play, Blade, Vaadin & Co 3
Dimax Im Spring ,Mysql-Funktion aufrufen Frameworks - Spring, Play, Blade, Vaadin & Co 2
OnDemand Spring Security/Boot/Vaadin Cookie Problem bei iFrame Frameworks - Spring, Play, Blade, Vaadin & Co 4
OnDemand Spring Boot: Feld ignorieren Frameworks - Spring, Play, Blade, Vaadin & Co 3
8u3631984 Spring + Thymleaf : Checkbox Object mappen Frameworks - Spring, Play, Blade, Vaadin & Co 0
N Buch zum Spring Framework bzw. Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 3
OnDemand Jasypt Spring Boot HIbernate wie komme ich an den Key? Frameworks - Spring, Play, Blade, Vaadin & Co 4
8u3631984 Spring Boot im Docker Container - Logback wird nicht verwendet Frameworks - Spring, Play, Blade, Vaadin & Co 13
sascha-sphw Spring - Authentication object was not found Frameworks - Spring, Play, Blade, Vaadin & Co 3

Ähnliche Java Themen

Neue Themen


Oben