SQLException
Newbie
- Registriert
- Juli 2019
- Beiträge
- 2
Hallo zusammen,
ich bin neu hier und habe direkt mal eine Frage, die mich schon seit Tagen beschäftigt. Sicherlich gibt es nicht den einen richtigen Weg und deshalb finde ich nichts, was mir weiterhilft.
Ich arbeite zur Zeit an einer WPF-Andwedung. Die Daten sind in einer MS SQL Datenbank gesichert. Dazwischen hängt eine Web-API.
Das ist aber eigentlich alles nicht relevant. Kommen wir also jetzt zum Thema:
In der Datenbank gibt es Benutzer die mehrere Benutzerrollen haben können. Einer Benutzerrolle sind mehrere Rechte zugeordnet.
Jetzt frage ich mich, wann ich die Rechte der Benutzer aus der Datenbank laden soll.
Bei einem erfolgreichem Login werden Benutzerdaten aus der Datenbank geladen und in einem Benutzerobjekt gespeichert. Später soll geprüft werden auf welche Funktionen der Anwendung der Benutzer zugreifen darf.
Sollte ich im Benutzerobjekt dann direkt seine Rollen und Rechte speichern? Nachteil wäre, dass wenn ich einfach nur etwas über einen Nutzer wissen will, ich automatisch alle Benutzerrollen, die mich ggf. gar nicht interessieren mit lade. Und wenn ich eine Liste an Nutzern lade, die gleichen Rollen zugeordnet sind, würde ich die Rollen doppelt und dreifach laden.
Oder sollte ich eine Funktion schreiben, die nur dann die Rollen und Rechte abruft, wenn ich sie benötige? Nachteil wäre hier, dass ich wohl viel mehr Anfragen an die Web-API senden müsste.
Zur Info: die Sicherheit hat hier nicht die höchste Priorität, da serverseitig sowieso nochmal geprüft wird, ob der Nutzer die Funktion auch ausführen darf.
Würde mich sehr über ein paar Tips freuen!
Das war ja jetzt schon recht speziell. Man kann die Frage auch allgemeiner Stellen:
Wenn man Objekte aus der Datenbank laden will, die mit anderen Objekten verknüft sind. Sollte man dann zunächst nur das, was man benötigt aus der Datenbank laden oder Direkt das vollständige Objekt?
ich bin neu hier und habe direkt mal eine Frage, die mich schon seit Tagen beschäftigt. Sicherlich gibt es nicht den einen richtigen Weg und deshalb finde ich nichts, was mir weiterhilft.
Ich arbeite zur Zeit an einer WPF-Andwedung. Die Daten sind in einer MS SQL Datenbank gesichert. Dazwischen hängt eine Web-API.
Das ist aber eigentlich alles nicht relevant. Kommen wir also jetzt zum Thema:
In der Datenbank gibt es Benutzer die mehrere Benutzerrollen haben können. Einer Benutzerrolle sind mehrere Rechte zugeordnet.
Jetzt frage ich mich, wann ich die Rechte der Benutzer aus der Datenbank laden soll.
Bei einem erfolgreichem Login werden Benutzerdaten aus der Datenbank geladen und in einem Benutzerobjekt gespeichert. Später soll geprüft werden auf welche Funktionen der Anwendung der Benutzer zugreifen darf.
Sollte ich im Benutzerobjekt dann direkt seine Rollen und Rechte speichern? Nachteil wäre, dass wenn ich einfach nur etwas über einen Nutzer wissen will, ich automatisch alle Benutzerrollen, die mich ggf. gar nicht interessieren mit lade. Und wenn ich eine Liste an Nutzern lade, die gleichen Rollen zugeordnet sind, würde ich die Rollen doppelt und dreifach laden.
Oder sollte ich eine Funktion schreiben, die nur dann die Rollen und Rechte abruft, wenn ich sie benötige? Nachteil wäre hier, dass ich wohl viel mehr Anfragen an die Web-API senden müsste.
Zur Info: die Sicherheit hat hier nicht die höchste Priorität, da serverseitig sowieso nochmal geprüft wird, ob der Nutzer die Funktion auch ausführen darf.
Würde mich sehr über ein paar Tips freuen!
Das war ja jetzt schon recht speziell. Man kann die Frage auch allgemeiner Stellen:
Wenn man Objekte aus der Datenbank laden will, die mit anderen Objekten verknüft sind. Sollte man dann zunächst nur das, was man benötigt aus der Datenbank laden oder Direkt das vollständige Objekt?