OOP Programmstrukturierung: UserManager für Webanwendung

e:ke

Neues Mitglied
Hallo,
ich hoffe hier ein paar Tipps für eine kleine Java Webanwendung zu bekommen. Ich habe zwar Programmiererfahrung, allerdings nicht im Bereich OOP. Was mir quasi fehlt ist das objektorientierte Denken bzw. Herangehen beim Codeaufbau. Intuitiv würde ich einfach alles strukturiert prozedural abarbeiten... Mit diesem Projekt möchte ich die OOP etwas trainieren.
Konkret geht es um einen UserManager für eine JSF Webabwendung. Ich habe also ein "Java-Web-Application" Projekt in Eclipse mit Tomcat 8.5 und PrimeFaces aufgesetzt. Grundsätzlich läuft die Infrastruktur soweit. Mein UserManager soll in der Lage sein folgende Funktionen für den User bereit zu halten:
  1. User registrieren (Mail + Password)
  2. User einloggen --> Zugriff auf gesicherten Bereich
  3. User löschen
  4. User ausloggen
  5. User Passwort ändern
Weiterhin ist es natürlich erforderlich, dass die Daten aller User irgendwie gespeichert werden. Als Textdatei macht das vermutlich nur für eine Übungsaufgabe Sinn. Ich habe mir folgende Strukturierung überlegt:
Es gibt also eine Klasse User:
Java:
public class User {
    public String username;
    public String password;
  // + getter + setter methods...
}
Für die Schnittstelle mit der Webseite gibt es eine Bean Klasse, in der ich NUR die Daten halten möchte, die auch benötigt werden. Der Tomcat verwendet die Getter/Setter Methoden, um username und password mit den entsprechenden Formularen der XHTML Seite zu verknüpfen.
Java:
@ManagedBean
@SessionScoped
public class LoginBean implements Serializable {
    private String username;
    private String password;
    //...
    public String doLogin() {
       System.out.println("LoginBean.doLogin");
     //...
    }  
public String doLogout() {
       System.out.println("LoginBean.doLogout");
     //...
    }  
public String doRegister() {
       System.out.println("LoginBean.doRegister");
     //...
    } 
// + getter + setter methods...
}

Für solch ein Login Bean habe ich ein einfaches Beispiel gefunden. Allerdings sind die username und password dort explizit im Code angegeben. Jetzt möchte ich das ganze etwas erweitern und habe eine Klasse UserManager gebaut, die alle vorhandenen und zukünftigen User in einem Vektor halten soll. Es gibt dort also etwas wie:
Java:
  Vector<User> users = new Vector<User>();
Somit sollen sämtliche User in dem Vektor users gehalten werden.
Von der Klasse User werden also immer wieder Objekte erzeugt und in users abgelegt oder mit den Einträgen dort verglichen. Der UserManager soll sinngemäß folgende Methoden enthalten:
  1. loadUsersFromDataBase
  2. writeUsersToDataBase
  3. addUser
  4. validateUser
  5. deleteUser
Vom UserManager sollen also nicht ständig neue Objekte erzeugt werden, er soll den Vektor aller User nur einmal halten und bearbeiten. Beim laden der Webseite und damit über das Bean muss irgendwie der UserManager gestartet werden, der am Anfang die Daten von Platte laden muss. Sobald ein neuer User hinzu kommt, muss auch die Datenbank geschrieben werden, denn sobald die Session stirbt, ist auch der UserManager nicht mehr da.

Hier bin ich allerdings am Ende: Wie starte ich den UserManager vom LoginBean aus? Irgendwie sehe ich nicht den "Anfang" des ganzen Programms. Es gibt schließlich kein "Main".
Wenn es dann ein einziges Objekt des UserManagers gibt, wer erzeugt es? und wie können die anderen Klassen dann die Methoden des UserManagers aufrufen? Die Klasse User kann ich mir bildlich vorstellen, die des UserManagers irgendwie nicht. Ist der ganze Ansatz schlecht gewählt? Sollte der User selbst die Methoden (z.B. hinzufügen zu Datenbank users) besitzen? Aber welche Klasse hat dann die Daten users?
Mittlerweile bin ich ziemlich verwirrt...
PS: Was wäre der geeignete Weg, die Daten zu speichern? Eine SQL Datenbank? Oder gibt es etwas "kleineres"?
 

sascha-sphw

Top Contributor
Auf Server Seite hat sich die Schichtenarchitektur bewährt. Das würde in Deinem Fall bedeuten, der UserManager wird ein UserDAO und erledigt das Laden der User aus der DB.
Ich würde auch nicht immer alle User aus der Datenbank vorhalten, Du wirst sie in einer Session ja nicht alle brauchen. Hier solltest Du nur den aktuellen User laden.

Bei Server Anwendungen bin ich ein großer Fan von Stateless, somit sollte der Server auch keine Session starten, hier würde ich mit JWT die relevanten Daten mitschicken.

Solltest Du dennoch Deinen Ansatz weiter verfolgen wollen, mit einem Server Container hat man die Möglichkeit einen Context Listener hinzuzufügen. Damit kannst Du dann beim Starten Deinen UserManager erzeugen und beim Stoppen entsprechend wieder aufräumen. https://docs.oracle.com/javaee/6/api/javax/servlet/ServletContextListener.html

PS: Was wäre der geeignete Weg, die Daten zu speichern? Eine SQL Datenbank? Oder gibt es etwas "kleineres"?
Eine SQL Datenbank ist der geeignete Weg.
 

Manuel.R

Bekanntes Mitglied
ich würde den Vorgang zum Logging etwas anders strukturieren:

Code:
@Named
@RequestScoped
public class LoginCredentials {
  
    private String userName;
  
    private String password;

    public LoginCredentials() {
        super();
    }

    public String getUserName() {
        return userName;
    }

    public void setUserName(String userName) {
        this.userName = userName;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }
}

Die eigegebenen Daten werden im Anschluss über einen Controller verifiziert. Die Eingabe von Passwort und Benutzername ist selbst nur im Request-Mode. Somit werden die Eingabe nach Beendigung der Anfrage von Container verworfen.

Code:
package org.fourd.phase.configuration;

import java.io.Serializable;
import java.util.ResourceBundle;
import java.util.logging.Level;
import java.util.logging.Logger;

import javax.enterprise.context.SessionScoped;
import javax.enterprise.inject.Produces;
import javax.faces.application.Application;
import javax.faces.application.FacesMessage;
import javax.faces.context.FacesContext;
import javax.inject.Inject;
import javax.inject.Named;

import org.fourd.pages.Pages;

/**
* @author Manuel
*
*/
@Named
@SessionScoped
public class LoginController implements Serializable
{
    private static final long serialVersionUID = -684028620835489337L;
    /**
     * Through CDI the necessary object for evaluating the login credentials
     * were injected in - loginController provides the typed in username and
     * password - the userManager is checking the typed in credentials against
     * existing data in the xml file - if credentials match to an existing user
     * the user become the currentUser
     */
    @Inject
    private LoginCredentials loginCredentials;
  
    @Inject
    private UserManager userManager;
  
    //@Inject
    //private LanguageController languageController;
  
    private Logger logger = Logger.getLogger(this.getClass().getName());
  
    private User currentUser;

    /**
     * Login-Method is responsible for the login action. The username and password from the view
     * (loginController)
     * @return
     */
    public String doLogin()
    {
        FacesContext context = FacesContext.getCurrentInstance();
        Application app = context.getApplication();
        ResourceBundle resourceBundle = app.getResourceBundle(context, "msg");
      
        String errorMsg = resourceBundle.getString("error_msg_login_failed");
      
        boolean login = false;
      
        try
        {
            currentUser = userManager.findUser(loginCredentials.getUserName(), loginCredentials.getPassword());
            if(currentUser!=null)
            {
                login = true;
            }else
            {
                FacesContext.getCurrentInstance().addMessage(null, new FacesMessage(FacesMessage.SEVERITY_ERROR, "Error!", errorMsg));
            }
        } catch (Exception e)
        {
            logger.log(Level.SEVERE, "Error do Login: "+e.getMessage());
        }
      
        if(login){
            FacesContext.getCurrentInstance().getExternalContext().getSessionMap().put("currentUser", currentUser);
            return Pages.HOME_VIEW;
        }else{
            return null;
        }
    }
  
    public String doShowProjects(){
        return Pages.PROJECT_VIEW;
    }

    @Produces
    @CurrentUser
    public User getCurrentUser() {
          return currentUser;
    }
}

über CDI kann dann im Anschluss auf den Benutzer der Session zugegriffen werden, wenn eine Benutzer-Verifikation notwendig wird.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
E frage zu programmstrukturierung Java Basics - Anfänger-Themen 5
M Code aus IntelliJ in "Textform" für Word-Paper? Java Basics - Anfänger-Themen 2
G Icon für App Java Basics - Anfänger-Themen 1
Kerstininer Vererbung Hilfe beim lernen von Objektorientierung für eine Klausur Java Basics - Anfänger-Themen 10
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
V Durchschnittliche Volatility in Prozent für 4 Stunden berechnen Java Basics - Anfänger-Themen 14
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
C negamax-Algorithmus für Tic-Tac-Toe spielt manchmal falsch Java Basics - Anfänger-Themen 10
D Apache HTTPClient für alle Fälle Java Basics - Anfänger-Themen 41
J Layout Manager, welcher ist der Richtige für mein Program? Java Basics - Anfänger-Themen 1
J Fehlermeldung unverständlich für Jakarta Java Basics - Anfänger-Themen 17
M Minimax-Algorithmus für Vier gewinnt Java Basics - Anfänger-Themen 11
M GUI für Vier-Gewinnt. Java Basics - Anfänger-Themen 4
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
D Quellcode für cmd funktioniert nicht Java Basics - Anfänger-Themen 9
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
R Operatoren Rechenoperation verwenden für Taschenrechner. Java Basics - Anfänger-Themen 32
Ostkreuz Counter für Booleanwerte Java Basics - Anfänger-Themen 8
B Regex Ausdrücke für Monate Java Basics - Anfänger-Themen 7
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
K loop pausieren für eine bestimmte Anzahl? Java Basics - Anfänger-Themen 1
Jxhnny.lpz Randomisier für Buttons Java Basics - Anfänger-Themen 13
W Intuitive interface für Komponenten Java Basics - Anfänger-Themen 4
M "Class<T> clazz" im Constructor - auch für int möglich? Java Basics - Anfänger-Themen 7
B Schrankensystem mit Farberkennung für Flashgame funktioniert nicht wie geplant Java Basics - Anfänger-Themen 4
I Code für Bezahlsystem (auch bei Offline Aktivität) Java Basics - Anfänger-Themen 7
U jUnit 5 Test für eine addMethode Java Basics - Anfänger-Themen 18
M monte carlo Algorithmus für 4 gewinnt Java Basics - Anfänger-Themen 12
frager2345 Java Singleton Muster -> Methode für Konstruktor mit Parametern Java Basics - Anfänger-Themen 3
izoards Sortier Algorithmus für Bounding Box Elememte Links nach Rechts und von Oben nach Unten Java Basics - Anfänger-Themen 33
M generate Methode für Streams Java Basics - Anfänger-Themen 6
I Datenmodell für "Tags" Java Basics - Anfänger-Themen 6
Lion.King for-Kontrollstruktur für Pyramide Java Basics - Anfänger-Themen 8
B Mit Countdown Midnestdauer für Teilaufgabenerledigung erzwingen Java Basics - Anfänger-Themen 8
J File length als Prüfwert für Download Java Basics - Anfänger-Themen 5
K Spieleidee gesucht für Informatikprojekt - JAVA (BlueJ)? Java Basics - Anfänger-Themen 15
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
javamanoman Java für Online Banking Java Basics - Anfänger-Themen 12
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
JordenJost Java ist auch eine Insel für Anfänger Java Basics - Anfänger-Themen 2
P9cman Tipps für Rekursive Aufgaben mit Strings oder allgemein Java Basics - Anfänger-Themen 2
F Suche nach betreuender Person für eine Jahresarbeit der 12. Klasse. Java Basics - Anfänger-Themen 6
I SQL / JPA Query für StartDate und EndDate Java Basics - Anfänger-Themen 1
T getMethode für ein Array Java Basics - Anfänger-Themen 2
Fats Waller Farben mixen für den Hintergrund ? Java Basics - Anfänger-Themen 1
H Suche jemanden für kleine Uni-Abgabe/ mit Vergütung Java Basics - Anfänger-Themen 1
K Für was braucht man die left und right shift operatoren? Was bringen die, also welchen Zweck haben die? Java Basics - Anfänger-Themen 15
N Api nur für Textdatein (.txt) Java Basics - Anfänger-Themen 2
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
R Ist Java das Richtige für mich? Java Basics - Anfänger-Themen 4
E Mittelquadratmethode für Hexadezimalzahlen Java Basics - Anfänger-Themen 1
P Einfacher regulärer Ausdruck (RegEx) für E-Mail-Adressen Java Basics - Anfänger-Themen 2
Kiki01 Wie würde eine geeignete Schleife aussehen, die die relative Häufigkeit für jeden Charakter in einem Text bestimmt? Java Basics - Anfänger-Themen 3
N Fehler im Code (Aufgabe für Anfänger) Java Basics - Anfänger-Themen 11
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
S BubbleSort für ArrayLists Java Basics - Anfänger-Themen 3
T Übungsbuch für Anfänger Java Basics - Anfänger-Themen 3
L Konzept für Quiz Java Basics - Anfänger-Themen 33
D Methoden Plathhalter für Integer in einer Methode Java Basics - Anfänger-Themen 19
B Datentyp für Einzelnes Objekt oder Liste Java Basics - Anfänger-Themen 9
D Welche GUI Library für eine Client Server Chat App Java Basics - Anfänger-Themen 14
T Algorithmus für Index mit min-Wert Java Basics - Anfänger-Themen 2
Aqtox Hallo ich muss für die Schule ein Wuerfell Duell erstellen jedoch habe ich ein fehler Java Basics - Anfänger-Themen 4
L loop für Namen Java Basics - Anfänger-Themen 11
kxrdelis Konstruktor für ein Rechtwinkliges Dreieck Java Basics - Anfänger-Themen 10
S Fehler bei Code mit SubStrings für mich nicht auffindbar. Java Basics - Anfänger-Themen 4
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
I Entity erstellen, die für API gedacht ist Java Basics - Anfänger-Themen 33
C Archiv für eigene Klassen Java Basics - Anfänger-Themen 9
A Junit Test für MysqlDataSource JDBC Java Basics - Anfänger-Themen 3
Animal-Mother BMI Rechner erstellen für W/M Java Basics - Anfänger-Themen 7
E Kleines Java-Projekt für Anfänger Java Basics - Anfänger-Themen 10
A Java die richtige Programmiersprache für mein Projekt? Java Basics - Anfänger-Themen 1
I DecimalFormat in Zahlenformat für Währung, habe 7,99, bekomme aber 7 Java Basics - Anfänger-Themen 4
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
Kanaska Datentyp für Zahlenbereiche Java Basics - Anfänger-Themen 7
T Startbildschirm für ein Spiel erstellen Java Basics - Anfänger-Themen 0
U BestPractise für Deployment unter Windows gesucht Java Basics - Anfänger-Themen 12
lilrack UML Diagramm für Parkplatzverwaltung Java Basics - Anfänger-Themen 8
W Mehrfach das gleiche Attribut für ein Objekt erzeugen (mit verschiedenen Werten) Java Basics - Anfänger-Themen 2
B Generische Typen für dynamisches Formular Java Basics - Anfänger-Themen 3
C Was ist nötig für ein Java-Programm auf Server für Website Java Basics - Anfänger-Themen 18
T Vererbung Verschiedene Attribute für vererbte Klassen Java Basics - Anfänger-Themen 4
T Start-Activity für Java Maven Web-Anwendung festlegen Java Basics - Anfänger-Themen 2
T Alternative für switch case Java Basics - Anfänger-Themen 1
P Ressourcen für JSON & API Informationen? Java Basics - Anfänger-Themen 1
M Java Einstellung von Apache POI für MS Word Erstellung mit Eclipse Java Basics - Anfänger-Themen 6
L Compiler-Fehler SupressWarning für clone() Java Basics - Anfänger-Themen 6
P Wie für EIN Java Programm von 64bit Java (=Standard) auf 32bit Java Installation (Windows) umschalten? Java Basics - Anfänger-Themen 6
B Methode für jede beliebe Entity erstellen Java Basics - Anfänger-Themen 7
D Ampel für Mitarbeiter zum An-/Abwesend zeigen Java Basics - Anfänger-Themen 28
T Wahrscheinlichkeiten für Slot Machine Java Basics - Anfänger-Themen 13
C Konvertierung des int typs in den double typ für die Ausgabe mit Nachkommastellen Java Basics - Anfänger-Themen 4
M Code nur für Cracks? Crack the Passwort Übung Java Basics - Anfänger-Themen 7
L Konstruktor für eine Map-Datei/Map-Datei einlesen Java Basics - Anfänger-Themen 5
T Roulette für Anfänger Java Basics - Anfänger-Themen 7
A Überprüfung für unentschieden in TicTacToe Java Basics - Anfänger-Themen 10

Ähnliche Java Themen

Neue Themen


Oben