Speicherablage für Authentification

danielmaann

Mitglied
Hallo zusammen

Ich schreibe aktuell an einer Applikation welche auf Spring Boot basiert. Später sollten andere Technologien (HTML, android, iOS,...) mit dieser Applikation kommunizieren können. Diese Applikation kann nur verwendet werden wenn man angemeldet ist.

Aktuell: Bei der Registrierung wird alles dahinter in eine DB abgelegt.
Da diese Applikation stateless ist, will ich das jedesmal überprüft wird, ob der Benutzer eingeloggt ist und dies ohne irgendwelche Sessions.
Nun habe ich mir folgendes gedacht:
Ich setze eine zweite Applikation um und beim einloggen wird ein Token generiert welches dann irgendwo abgespeichert wird. Dieses Token kriegt der Benutzer zurück. Anhand diesen Tokens sollte überprüft werden ob der Benutzer eingeloggt ist bzw. existiert dieses Token.

Einfach gesagt, bei jedem Request auf diesen Server wird halt noch ein Token mitgegegen. Dieses Token wird dann an die zweite Applikation übergeben zum überprüfen ob er angemeldet ist oder nicht (sprich, true oder false).

Meine Frage ist nun:
Wie sollte ich das am besten machen? Wäre dieser Ansatz gut welcher ich vor habe? Verbesserungsvorschläge? oder kann ich das so machen ohne später Probleme zu kriegen?

Zweite Frage:
Wo sollte ich das Token ablegen?
  • Wenn ich es in ein Array hinterlege, wird es bei einen Benutzerzahl von 1000+ ein ziemlich grosses Array und RAM wird extrem belastet. Der zweite nachteil ist, wenn der Server abstürzt, müssen sich die Benutzer erneut anmeldet damit ein Token wieder generiert wird.
  • Sollte ich es in ein File ablegen? Da weiss ich nicht, wie schnell das File gelesen werden kann bzw. hineingeschrieben werden kann. Da pro Request und pro User, das Token aus dem File gelesen werden muss. Somit wäre der Ansatz mit einem Array oder mit eine Map schneller. Wie funktioniert das, beim schreiben in eine Datei mit 1000+ bereits eingetragenen Tokens? funktioniert das gleich schnell? Was passiert wenn sich 100 User zur selben Zeit anmelden?
  • Sollte ich eine Datenbank nehmen, bzw. die Daten in eine DB ablegen? Vorteil ist, das man das spiegeln kann und das es schnell ist. Aber Nachteil ist, ich bräuchte einen Server mehr.
Was denkt ihr?

Sonst noch verschläge?
 

HarleyDavidson

Bekanntes Mitglied
Grundsätzlich ist die Trennung von Usermanagement (also Authentifizierung) und eigentlicher Logik immer gut. Vielleicht ist dieser Link für dich interessant: https://tools.ietf.org/html/rfc6749
Möchtest du nicht gleich so groß mit einem OAuth Framework einsteigen, kann ich dir als Datenbank die H2 Datenbank empfehlen: http://www.h2database.com
Für diese benötigst du keinen extra Server. Ich bin sehr zufrieden damit und für ein Token-Handling ist diese Wahl in Sachen Performance absolut zu empfehlen.
 

danielmaann

Mitglied
@HarleyDavidson super, cool. Werde mich einlesen. Wenn ich aber keinen Server für die DB brauche, kann ich nicht 2 von den Authservern haben welche auf die DB zugreifen und davor einen loadbalancer stellen um die anfragen auszugleichen. Das wäre der nachteil. Danach folgt ja der nachteil das die DB nicht kopiert werden kann bzw. wenn es einen systemausfall geben würde.

@thecain jwt kenne ich nicht. durch den wikipedia beitrag sieht mir diese methode ziemlich simple aus. Nachteile?

@mrBrown bezüglich dem oAuth2 kenne ich mich zu wenig aus und für mich scheint diese Sache ziemlich komplex zu sein, habe mal vor 2 Monaten mich mit dem oauth2 von Spring herumgeschlagen und kam nicht weit. War alles schon zu komplex für mich, vielleicht liegt es auch an dem fehlenden Versändniss im Englisch. Naja, kenne bei der application.properties (application.yml) die zusammehänge nicht zwischen den properties und welche für was zuständnig sind
 

mrBrown

Super-Moderator
Mitarbeiter
@HarleyDavidson super, cool. Werde mich einlesen. Wenn ich aber keinen Server für die DB brauche, kann ich nicht 2 von den Authservern haben welche auf die DB zugreifen und davor einen loadbalancer stellen um die anfragen auszugleichen. Das wäre der nachteil. Danach folgt ja der nachteil das die DB nicht kopiert werden kann bzw. wenn es einen systemausfall geben würde.
Da geht es übrigens um OAuth 2, H2 hat damit aber überhaupt nichts zu tun, genausowenig ob eine oder 2 Datenbanken...

Naja, kenne bei der application.properties (application.yml) die zusammehänge nicht zwischen den properties und welche für was zuständnig sind
Da hilft nur die Docs lesen, die sind bei Spring eig. recht gut...
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Algorithmus für Arbeit mit fehlenden Listenelementen? Allgemeine Java-Themen 1
kodela Eingabe für TextArray bedingt sperren Allgemeine Java-Themen 3
Karl_Der_Nette_Anfänger Hat wer ne Lösung für verknüpfte Postleitzahlen? (Baum/Wurzel Struktur) Allgemeine Java-Themen 11
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
G KeyListener für JTextField Allgemeine Java-Themen 5
webracer999 Library für Textsuche (z. B. include/exclude, and/or)? Allgemeine Java-Themen 5
I Module-Info für Jar erzeugen Allgemeine Java-Themen 7
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
B Simpler Eventlistener für Tastaturtaste bauen? Allgemeine Java-Themen 13
_user_q Eingegebenen Text Zeile für Zeile ausgeben lassen Allgemeine Java-Themen 11
E Key für TOTP Algorythmus(Google Authentificator) Allgemeine Java-Themen 0
S Formel für Sonnenwinkel in ein Programm überführen Allgemeine Java-Themen 11
M pfx-Zertifikat in Tomcat für SSL-Verschlüsselung nutzen Allgemeine Java-Themen 14
R Best Practice Erfahrungswerte für eine Migration von JSF nach Angular (oder anderes JS-Framework) Allgemeine Java-Themen 1
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
jhCDtGVjcZGcfzug Klassen Was genau passiert hier? Kann mir das jemand bitte Zeile für Zeile erklären? Allgemeine Java-Themen 1
rosima26 Bester Sortieralgorithmus für kurze Arrays Allgemeine Java-Themen 40
S Mit Methoden kann man definieren für was <T> steht. Geht das auch irgendwie für Variablen? Allgemeine Java-Themen 12
MangoTango Operatoren while-Schleife für Potenz Allgemeine Java-Themen 3
B Lottospiel, genug Reihen tippen für 3 Richtige (Spaß mit Arrays)? Allgemeine Java-Themen 46
B Mit welchen Datentypen und Strukturierung am Besten dutzende Baccaratspiele Shcritt für Schritt durchsimulieren? Allgemeine Java-Themen 26
D Klassendesign für einen Pascal Interpreter Allgemeine Java-Themen 6
I OCR Library für Belegerkennung Allgemeine Java-Themen 7
farah GetterMathod für Farbkanäle Allgemeine Java-Themen 6
B Welcher Datentyp für sehr große Zahlenbereiche? Allgemeine Java-Themen 1
S Webservices für binäre Daten? Allgemeine Java-Themen 5
G Licence-Header für InHouse entwickelten Source Allgemeine Java-Themen 8
M Schleife für einen TicTacToe Computer Allgemeine Java-Themen 5
O git ignore für Intellji braucht es die .idea Dateien? Allgemeine Java-Themen 8
F Java Script für das Vorhaben das richtige? Allgemeine Java-Themen 9
M wiviel Java muss ich für die Berufswelt können ? Allgemeine Java-Themen 5
Robertop Datumsformat für GB ab Java 16 Allgemeine Java-Themen 1
Thallius Verschiedene entities für gleichen Code…. Allgemeine Java-Themen 8
OnDemand Zentrale "Drehscheibe" für verschiedene APIs Allgemeine Java-Themen 14
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
D SHA-3 für Java-version 1.8 Allgemeine Java-Themen 1
N Validator für einen SQL-Befehl Allgemeine Java-Themen 22
Muatasem Hammud Erstellung von Testdaten für Arrays Allgemeine Java-Themen 6
B Logikfehlersuche, das perfekte Lottosystem für 3 Richtige mit Arraylists? Allgemeine Java-Themen 61
G Methoden für die Zukunft sinnvoll? Allgemeine Java-Themen 4
M API für PLZ Umkreissuche Allgemeine Java-Themen 3
1Spinne JDK 8 für Eclipse installieren Allgemeine Java-Themen 5
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
L Methoden Parser für gängige Datumsformate? Allgemeine Java-Themen 1
H Interface PluginSystem ClassNotFound exception für library Klassen Allgemeine Java-Themen 10
N relativier Pfad für sqlite-Datenbank in Gradle/IntelliJ Allgemeine Java-Themen 2
buchfrau Anagram für beliebiges Wort Allgemeine Java-Themen 2
TonioTec Api für Datenaustausch zwischen Client und Server Allgemeine Java-Themen 0
W Suche Ursache für NPE - woher kommt sie? (Hilfe beim Debugging) Allgemeine Java-Themen 19
Kirby.exe Distanz Map für die Distanztransformation erstellen Allgemeine Java-Themen 1
F PI Regler für Heizung Allgemeine Java-Themen 7
8u3631984 Generelle Log4j.xml für alle Module Allgemeine Java-Themen 5
M Wie übergebe ich den Zähler für die Anzahl Rekursionsschritte korrekt? Allgemeine Java-Themen 2
B Login für User, der im Hintergrund Schedules ausführt Allgemeine Java-Themen 16
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
S Java-Task-Management-Tool für Windows und Mac selber programmieren Allgemeine Java-Themen 4
M Java 2D Array für ein Grid erstellen ? Allgemeine Java-Themen 2
Z Welches GUI Framework für Java ist aktuell? Allgemeine Java-Themen 16
N Convert.FromBase64 von C# für Java Allgemeine Java-Themen 11
N fixed-keyword von C# für Java Allgemeine Java-Themen 6
O Suche Scripter für alt:V Project! Allgemeine Java-Themen 0
S Interface Design von HookUp oder Callback Methoden für eigenes Framework Allgemeine Java-Themen 9
O Suche Unterstützung für ein OpenSource-Projekt (grafischer Editor) Allgemeine Java-Themen 13
Kirby.exe Software für Graphische Visualisierung Allgemeine Java-Themen 20
B OOP Auslöser für NullPointerException Allgemeine Java-Themen 3
L Generator für einen Parser implementieren Allgemeine Java-Themen 13
DonMalte Ambitioniertes Projekt für Einsteiger & Motivierte Allgemeine Java-Themen 0
Kirby.exe Movement System für Spiel Allgemeine Java-Themen 13
Kirby.exe Framework für Game Design Allgemeine Java-Themen 8
W Alternative für Threads Allgemeine Java-Themen 6
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
Thallius Rätsel für Windows Profis Allgemeine Java-Themen 8
D OOP Gemeinsamen ID-Raum für zwei Klassen implementieren Allgemeine Java-Themen 7
D Input/Output Implementierung eines CommandHandlers/Parsers für viele Eingaben Allgemeine Java-Themen 26
Thallius Alternative für SwingWorker Allgemeine Java-Themen 5
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Datenstruktur für eine Map erstellen Allgemeine Java-Themen 2
H OOP Setting(config) für Applikation sicheren? Allgemeine Java-Themen 9
OnDemand PDF Libary für Formulare Allgemeine Java-Themen 7
S Warmup für Lineare-Suche mit Zeitmessung Allgemeine Java-Themen 2
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
M Brainstorming für mein Projekt Allgemeine Java-Themen 30
K OOP Suche Hilfe + Erklärung für eine Hausaufgabe Allgemeine Java-Themen 1
F Was ist der Dateityp meines Parameters für die Main Methode. Allgemeine Java-Themen 6
C Bibliotheken für Algorithmische Geometrie Allgemeine Java-Themen 2
C Daten für Klassifikationsverfahren gewinnen Allgemeine Java-Themen 6
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
I Overlay für Spiele Allgemeine Java-Themen 5
B Suche nach einem Testprogramm für meine BA Allgemeine Java-Themen 0
I GUI für kleine Pop-Ups unter Windows Allgemeine Java-Themen 1
A NetBeans Suche Programmierer für eine Belegarbeit Allgemeine Java-Themen 11
HarleyDavidson Best Practice Wohin mit der Konfigurationsdatei für Desktopapplikationen? Allgemeine Java-Themen 3
R MAC-Adresse eindeutig für einen PC ? Bezug zu Netzwerk, wieso ? Allgemeine Java-Themen 7
N Java API für CardDav und CalDav gesucht Allgemeine Java-Themen 4
R Idee für Methodenrumpf Allgemeine Java-Themen 5
O Suche größeres Beispiel für WebserverAnwendung mit Java Allgemeine Java-Themen 2
K Anregungen für Bilderanalyse in Java Allgemeine Java-Themen 1

Ähnliche Java Themen

Neue Themen


Oben