Webanwendung und Spring Security Ratschlag

dmike

Bekanntes Mitglied
Folgendes Szenario:

Ein Kernanwendung soll zunächst per Web-Client benutzt werden. Der User muss sich im Web authentifizieren. Das Passort soll natürlich verschlüsselt werden. Später kann auch ein GUI oder WebService Client dazu kommen:

Was ist jetzt der "bessere" Weg:

a) Spring Security ist Teil der Webanwendung und erledigt das Ver/Entschlüsseln von Passwörtern als Teil der Webschicht.

b) Spring Security ist Teil bzw. eine dünne Schicht der Kernanwendung, so dass die Webanwendung vom Verschlüsselungsprozess nichts weiß.


Bei A) sehe ich das Problem, dass die Klients unter Umständen alle eine eigene Verschlüsselung realisieren, die nicht zwangsläufig kompatibel unter einander sein müssen. D.h. pro Client muss die Authentifizierung neu geschrieben unte konfiguriert werden (verletzt DRY)


Bei B) sehe den Nachteil, dass das Passwort nicht sofort in der Webschicht verschlüsselt, sondern als Plaintext an die Kernanwendung geschickt wird. Falls das aber über http geschieht, hat man aber immer noch https als Sicherheit.

Also wie sollte man Spring Security verwenden? Sollte es Teil des Clients, bzw. der Webschicht sein oder doch Teil der Kernanwendung?
 

tagedieb

Top Contributor
Option A: Spring Security wird als Web-Filter konfigurativ integriert. Dabei ist die Security von der restlichen (Web-)Applikation losgeloest und kann bei bedarf geaendert oder ersetzt werden. Dabei spielt es keine Rolle, ob Username/Passwort via Basic-, Digest- oder Form-Authentication erfragt werden. Das Login sollte aber doch via https zusaetzlich verschluesselt werden, da die Basic- und Form-Authentication das Passwort in Plaintext uebermitteln. Wie gesagt dies kann alles per Spring Security Konfiguriert werden und weder deine Core- noch deine Web-Applikation braucht sich darum zu kuemmern

Option B: Wenn ich richtig verstehe soll die Web-Applikation lediglich das Login-Form anzeigen und die Kern-Applikation uebernimmt die Authentifizierung? Das bringt meines Erachtens nichts. Das Verschluesseln der Passwoerter sollte eh Spring Security uebernehmen (MD5, SHA), damit die Security Transparent bleibt und sich die Applikation nicht darum kuemmern muss. Ausserdem bleibt dann die Web-Applikation ungesichtert, welches wiederum Moeglichkeiten fuer einen Angriff bietet.
 

dmike

Bekanntes Mitglied
Option A: Spring Security wird als Web-Filter konfigurativ integriert. Dabei ist die Security von der restlichen (Web-)Applikation losgeloest und kann bei bedarf geaendert oder ersetzt werden. Dabei spielt es keine Rolle, ob Username/Passwort via Basic-, Digest- oder Form-Authentication erfragt werden. Das Login sollte aber doch via https zusaetzlich verschluesselt werden, da die Basic- und Form-Authentication das Passwort in Plaintext uebermitteln. Wie gesagt dies kann alles per Spring Security Konfiguriert werden und weder deine Core- noch deine Web-Applikation braucht sich darum zu kuemmern

Option B: Wenn ich richtig verstehe soll die Web-Applikation lediglich das Login-Form anzeigen und die Kern-Applikation uebernimmt die Authentifizierung? Das bringt meines Erachtens nichts. Das Verschluesseln der Passwoerter sollte eh Spring Security uebernehmen (MD5, SHA), damit die Security Transparent bleibt und sich die Applikation nicht darum kuemmern muss. Ausserdem bleibt dann die Web-Applikation ungesichtert, welches wiederum Moeglichkeiten fuer einen Angriff bietet.



Veilleicht geht auch folgende Variante zu Option B:

B.1) Spring Security sichert sowohl die Kern-Applikation (per role- bzw. method security) als auch die Web-Applikation ab.

B.2) Lediglich die Aufgabe der Passwortverwaltung wird Spring Security an die Kernapplikation übertragen. Spring Securirty leitet dabei alle Anfragen bzgl. Passwort-vergleiche, etc. an die Kern-App weiter.


Ohne B.2) hätte ich folgende Bedenken.

- Ohne die Web-Applikation bleibt die Kern-Applikation völlig ungesichert, könte z.B. keine User authentifizieren. (z.B. im consolen Modus).

Jeder neue Klient müsste die Verschlüsselungsprozedur neu entwickeln (abgesehen das DRY verletzt wird, können da auch Fehler passieren. Zum Beispiel passt der Verschlüsselungsalgo der Konsole nicht mit dem der Web-App überein, weil andere Bibliotheken oder Versionen dieser Bibliotheken verwendet werden oder der SALT müsste zwichen alle Clients synchronisiert werden)
 

tagedieb

Top Contributor
Spring Security sollte schon durchgehend sein. D.h. es sollte in der Web- wie auch in der Kern-Applikation verwendet werden um Authentifizierung und Autorisierung zu pruefen. Somit sind beide Applikation von der via Spring Security gesichtert und muessen sich nicht selber darum kuemmer. Somit wird auch die Security von der BusinessLogik getrennt (AOP).

Wenn ein User direkt auf die Kernapplikation zugreift wird Spring Security eine Authentisierung verlangen (mit einem AuthenticationManager fuer Standalone Applikationen).

Die Passworkverschluesselung wie auch Authentisierung sollte Spring Security uebernehmen und nicht in die Businesslogik eingebaut werden (Kern-Applikation). Solche Abhaengigkeiten sollten vermieden werden.

Spring Security bietet eine breite Unterstuetzung der Passworkverschluesselung (Salt, MD5, SHA,....) und es koennen natuerlich auch eigene Mechanismen implementiert werden.


Also die beste Loesung aus meiner Sicht ist es den Security Layer und die Busineslogik zu trennen. Die Businesslogik sollte generel Abhaengigkeiten zu den Aspekten Logging, Persistenz, TransactionHandling und Security vermeiden! Damit bleibt deine Code uebersichtlich und ist einfacher zu warten und zu erweitern. Sauberer Code! Auch vereinfacht sich auch das Testing via JUnit enorm, wenn man sich nicht all diese Abhaengigkeiten mittesten muss.
 

dmike

Bekanntes Mitglied
Ok, ich denke im Prinzip sehe ich das auch so wie von dir geschildert.

Im Moment ist halt Spring Security noch eng mit der Web-App verzahnt, was es ja auch so sein soll/muss. Es ist in dem Maven-Projekt auch im selben Modul untergebracht wie das Web.

Falls wir dann irgendwann auf einen App-Server umziehen, dann müssen wir wohl Spring Security aus diesem Web-Kontext herauslösen und so konfigurieren, dass auch eine Konsolen-App durch die Anwendung authentifiziert werden kann.

Was ich halt vermeiden möchte ist, dass jeder Klient, in diesem Fall Tomcat, seine eigene Security-Strategie mitbringt um sich gegen die Kern-Anwendung zu authentifizieren.

Theoretisch stelle ich mir (Spring) Security also als eine dünne Schicht (dein Stichwort AOP) um die Kernanwendung vor, die in der Lage ist die Anwendung für alle möglichen Klients (Web, Konsole, etc.) transparent und einheitlich mit Security zu versorgen. Wie gesagt liegt Spring Security aber im Moment noch sehr nahe an der Web-Entwicklung (ist Teil des selben Maven-Moduls wo auch die Webentwicklung passeirt) D.h. würde ich auf dieses Web-Modul verzichten, würde ich auch den Support von Spring Security verlieren.

Ich weiß daher nicht so recht, ob es möglich ist Spring Security etwas unabhängiger von dieser Webentwicklung zu machen, im dem Sinne, dass es sein eigenes Modul in Maven erhalten. Es würde dann sowohl das Web-Modul als auch das Core-Modul (die Kernanwendung) mit Security transparent und einheitlich versorgen Ob das technisch und vom Projektaufbau her so geht , weiß ich nicht.
 

tagedieb

Top Contributor
Welche Version von Spring Security verwendest du den? Es gibt keine Abhängigkeiten zu Web-Projekten. Aber es bittet natürlich eine sehr breite Unterstützung von Web Applikationen. Es lässt sich auch hier einfach via Konfiguration integrieren. Es ist keine Codeänderung nötig. Spring Security lässt sich problemlos auch in eine 'normale' Applikation integrieren. Natürlich musst du dann einen andern AuthentificationManager konfigurieren.

Für deine (Web-)Clients kannat du übrigens eine Defaultkonfiguration erstellen und am Besten gleich ein Maven Artifact daraus builden. Somit können alle dieselbe Konfig verwenden und es muss sich nicht jeder selber darum kümmern.
 

dmike

Bekanntes Mitglied
Ich benutz die Spring Security 3.0.5 (also ziemlich aktuell). Das mit der Default-Config ist ein guter Hinweise. Ich denke ich muss mch erst mal mit den Details beschäftigen :rtfm:
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
F Spring Webanwendung Datenbank Frameworks - Spring, Play, Blade, Vaadin & Co 47
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
S Spring Security mit oauth2 in lokaler Konfiguration principal mocken Frameworks - Spring, Play, Blade, Vaadin & Co 0
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
8u3631984 Welches Spring Frontend Framework verwendet ihr und wie bzw wo ? Frameworks - Spring, Play, Blade, Vaadin & Co 7

Ähnliche Java Themen

Neue Themen


Oben