From 296180d37b6169d94f665b7665a3ea3b4384e24f Mon Sep 17 00:00:00 2001 From: Oliver Hummel Date: Wed, 19 Oct 2022 18:49:43 +0200 Subject: [PATCH] =?UTF-8?q?Persistenz=20hinzugef=C3=BCgt.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../de/hs_mannheim/informatik/bank/Main.java | 3 +- .../informatik/bank/domain/Bank.java | 3 +- .../informatik/bank/domain/Girokonto.java | 4 +- .../informatik/bank/domain/Konto.java | 49 +++++++++++----- .../informatik/bank/domain/Kontobewegung.java | 3 +- .../informatik/bank/facade/Banksystem.java | 51 +++++++++------- .../bank/infrastructure/Persistenz.java | 47 +++++++++++++++ .../de/hs_mannheim/informatik/bank/ui/UI.java | 58 ++++++++++--------- 8 files changed, 150 insertions(+), 68 deletions(-) create mode 100644 Bank-Beispiel/src/de/hs_mannheim/informatik/bank/infrastructure/Persistenz.java diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java index b313f9f..16a794f 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java @@ -5,10 +5,9 @@ import de.hs_mannheim.informatik.bank.ui.UI; public class Main { - public static void main(String[] args) { + public static void main(String[] args) throws Exception { Banksystem bs = new Banksystem("Spaßkasse Mannheim"); UI ui = new UI(bs); - } } \ No newline at end of file diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Bank.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Bank.java index 5afd1be..f268979 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Bank.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Bank.java @@ -1,9 +1,10 @@ package de.hs_mannheim.informatik.bank.domain; +import java.io.Serializable; import java.util.Collection; import java.util.HashMap; -public class Bank { +public class Bank implements Serializable { private String name; private HashMap konten = new HashMap<>(); diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java index dfe1581..a6e7587 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java @@ -1,6 +1,8 @@ package de.hs_mannheim.informatik.bank.domain; -public class Girokonto extends Konto { +import java.io.Serializable; + +public class Girokonto extends Konto implements Serializable { public Girokonto(String inhaber) { super(inhaber); diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Konto.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Konto.java index 9db1967..6783f1f 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Konto.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Konto.java @@ -1,23 +1,36 @@ package de.hs_mannheim.informatik.bank.domain; +import java.io.IOException; +import java.io.Serializable; import java.util.ArrayList; -public class Konto { +import de.hs_mannheim.informatik.bank.infrastructure.Persistenz; + +public class Konto implements Serializable { private static int kontozähler = 0; - + + static { // die bislang eleganteste Lösung, die mir eingefallen ist + try { + if (Persistenz.sindDatenGespeichert()) + kontozähler = Persistenz.ladeKontozähler(); + } catch (IOException e) { + e.printStackTrace(); + } + } + private int nummer; private long stand = 0; private String inhaber; - + private ArrayList kontobewegungen; public Konto(String inhaber) { nummer = 1000 + kontozähler++; this.inhaber = inhaber; - + this.kontobewegungen = new ArrayList<>(); } - + public int getKontonummer() { return nummer; } @@ -26,42 +39,46 @@ public class Konto { public String toString() { return "Konto [nummer=" + nummer + ", inhaber=" + inhaber + "]"; } - + public String getInhaber() { return inhaber; } - + public long getKontostand() { return stand; } - + public void einzahlen(long betrag, String zweck, String art, String auftraggeber) { stand += betrag; - + kontobewegungen.add(new Kontobewegung(betrag, zweck, art, auftraggeber)); } - + public boolean auszahlen(long betrag, String zweck, String art, String auftraggeber) { if (stand - betrag >= 0) { stand -= betrag; - + kontobewegungen.add(new Kontobewegung(betrag * -1, zweck, art, auftraggeber)); - + return true; } - + return false; } - + public String[] getKontobewegungen() { String[] auflistung = new String[kontobewegungen.size()]; - + int i = 0; for (Kontobewegung kb : kontobewegungen) { auflistung[i++] = kb.toString(); } - + return auflistung; } + public int getKontozähler() { + return kontozähler; + } + } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Kontobewegung.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Kontobewegung.java index 8db257b..d6b15dd 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Kontobewegung.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Kontobewegung.java @@ -1,8 +1,9 @@ package de.hs_mannheim.informatik.bank.domain; +import java.io.Serializable; import java.util.Date; -public class Kontobewegung { +public class Kontobewegung implements Serializable { private long betrag; private Date datum; private String betreff; diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java index 53f351f..9c5b184 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java @@ -5,78 +5,87 @@ import java.util.Collection; import de.hs_mannheim.informatik.bank.domain.Bank; import de.hs_mannheim.informatik.bank.domain.Girokonto; import de.hs_mannheim.informatik.bank.domain.Konto; +import de.hs_mannheim.informatik.bank.infrastructure.Persistenz; public class Banksystem { private Bank bank; - - public Banksystem(String bankname) { - this.bank = new Bank(bankname); + + public Banksystem(String bankname) throws Exception { + if (Persistenz.sindDatenGespeichert()) + this.bank = (Bank) Persistenz.ladeBankDaten(); + else + this.bank = new Bank(bankname); } - - public int kontoAnlegen(String name, int auswahl) { + + public int kontoAnlegen(String name, int auswahl) throws Exception { Konto k; - + if (auswahl == 1) k = new Konto(name); else k = new Girokonto(name); - + bank.addKonto(k); -// System.out.println(k instanceof Girokonto); - + Persistenz.speichereBankDaten(this.bank); + Persistenz.speichereKontozähler(k.getKontozähler()); + return k.getKontonummer(); } - + public String[] getKontenliste() { Collection konten = bank.getKontenliste(); String[] liste = new String[konten.size()]; - + int i = 0; for (Konto k : konten) { liste[i++] = k.toString(); } - + return liste; } - + public String getBankname() { return bank.getName(); } - public long geldEinzahlen(int kontonummer, long betrag) { + public long geldEinzahlen(int kontonummer, long betrag) throws Exception { Konto konto = bank.findeKonto(kontonummer); konto.einzahlen(betrag, "Einzahlung am Schalter", "Einzahlung", konto.getInhaber()); - + + Persistenz.speichereBankDaten(this.bank); + return konto.getKontostand(); } - - public boolean geldAuszahlen(int kontonummer, long betrag) { + + public boolean geldAuszahlen(int kontonummer, long betrag) throws Exception { Konto konto = bank.findeKonto(kontonummer); + Persistenz.speichereBankDaten(this.bank); + return konto.auszahlen(betrag, "Auszahlung am Schalter", "Auszahlung", konto.getInhaber()); } public String[] erstelleKontoauszug(int kontonummer) { Konto konto = bank.findeKonto(kontonummer); - + return konto.getKontobewegungen(); } public boolean überweisungBeauftragen(int startkonto, int zielkonto, long betrag, String verwendungszweck) { Konto start = bank.findeKonto(startkonto); Konto ziel = bank.findeKonto(zielkonto); - + if (start instanceof Girokonto && ziel instanceof Girokonto) { return ((Girokonto)start).überweise((Girokonto)ziel, betrag, verwendungszweck); } - + return false; } public long getKontostand(int kontonummer) { Konto konto = bank.findeKonto(kontonummer); - + return konto.getKontostand(); } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/infrastructure/Persistenz.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/infrastructure/Persistenz.java new file mode 100644 index 0000000..b72919e --- /dev/null +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/infrastructure/Persistenz.java @@ -0,0 +1,47 @@ +package de.hs_mannheim.informatik.bank.infrastructure; + +import java.io.File; +import java.io.FileInputStream; +import java.io.FileNotFoundException; +import java.io.FileOutputStream; +import java.io.IOException; +import java.io.ObjectInputStream; +import java.io.ObjectOutputStream; + +public class Persistenz { + private static final String BANK_DATEI = "bank.ser"; + private static final String ZÄHLER_DATEI = "zähler.ser"; + + public static boolean sindDatenGespeichert() { + return new File(BANK_DATEI).exists(); + } + + public static void speichereBankDaten(Object bank) throws Exception { + ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(BANK_DATEI)); + oos.writeObject(bank); + oos.close(); + } + + public static void speichereKontozähler(int kontozähler) throws IOException { + ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(ZÄHLER_DATEI)); + oos.writeInt(kontozähler); + oos.close(); + } + + public static Object ladeBankDaten() throws Exception { + ObjectInputStream ois = new ObjectInputStream(new FileInputStream(BANK_DATEI)); + Object bank = ois.readObject(); + ois.close(); + + return bank; + } + + public static int ladeKontozähler() throws FileNotFoundException, IOException { + ObjectInputStream ois = new ObjectInputStream(new FileInputStream(ZÄHLER_DATEI)); + int zähler = ois.readInt(); + ois.close(); + + return zähler; + } + +} diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java index ddf9a15..c8adc83 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java @@ -27,7 +27,7 @@ public class UI { System.out.println("4 -> Geld auszahlen"); System.out.println("5 -> Kontoauszug drucken"); System.out.println("6 -> Überweisung beauftragen"); - + System.out.println("9 -> Beenden"); System.out.println(); @@ -35,23 +35,29 @@ public class UI { int input = Integer.parseInt(sc.nextLine()); System.out.println(); - switch(input) { + try { + switch(input) { case 1: kontenAnzeigen(); break; - case 2: kontoAnlegen(); break; + case 2: + kontoAnlegen(); + break; case 3: geldEinzahlen(); break; case 4: geldAuszahlen(); break; case 5: kontoauszugDrucken(); break; case 6: überweisungBeauftragen(); break; case 9: break mainloop; - } - + } + + } catch (Exception e) { + System.err.println(e.getLocalizedMessage()); + } System.out.println(); } System.out.println("Auf Wiedersehen!"); } // hauptmenü - + private void kontenAnzeigen() { String[] konten = bs.getKontenliste(); if (konten.length > 0) { @@ -64,10 +70,10 @@ public class UI { } } - private void kontoAnlegen() { + private void kontoAnlegen() throws Exception { System.out.println("Bitte den Namen des Kontoinhabers angeben: "); String name = sc.nextLine(); - + System.out.println("Möchten Sie ein Sparkonto (1) oder ein Girokonto (2) anlegen?"); int auswahl = Integer.parseInt(sc.nextLine()); @@ -75,41 +81,41 @@ public class UI { System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt."); } - private void geldEinzahlen() { + private void geldEinzahlen() throws Exception { System.out.println("Geld einzahlen"); System.out.print("Bitte die gewünschte Kontonummer eingeben: "); int kontonummer = Integer.parseInt(sc.nextLine()); - + // optional prüfen, ob Konto existiert - + System.out.print("Bitte den gewünschten Betrag eingeben: "); double betrag = Double.parseDouble(sc.nextLine()); - + long neuerKontostand = bs.geldEinzahlen(kontonummer, (long)betrag * 100); - + System.out.printf("Einzahlung erfolgreich, neuer Kontostand = %.2f Euro", (neuerKontostand / 100.0)); } - private void geldAuszahlen() { + private void geldAuszahlen() throws Exception { System.out.println("Geld auszahlen"); System.out.print("Bitte die gewünschte Kontonummer eingeben: "); int kontonummer = Integer.parseInt(sc.nextLine()); - + System.out.print("Bitte den gewünschten Betrag eingeben: "); double betrag = Double.parseDouble(sc.nextLine()); - + boolean erfolgreich = bs.geldAuszahlen(kontonummer, (long)betrag * 100); - + System.out.printf("Auszahlung" + ((!erfolgreich)? " nicht" : "" )+ " erfolgreich. "); System.out.printf("Neuer Kontostand = %.2f Euro.", (bs.getKontostand(kontonummer) / 100.0)); } - + private void kontoauszugDrucken() { System.out.print("Bitte die gewünschte Kontonummer für den Auszug eingeben: "); int kontonummer = Integer.parseInt(sc.nextLine()); - + System.out.println(); - + // in echt auf einem Drucker System.out.println("Auszug für Konto " + kontonummer); String[] kontobewegungen = bs.erstelleKontoauszug(kontonummer); @@ -117,22 +123,22 @@ public class UI { System.out.println(kb); } } - + private void überweisungBeauftragen() { System.out.print("Bitte die Kontonummer des Ausgangskontos der Überweisung eingeben: "); int startkonto = Integer.parseInt(sc.nextLine()); - + System.out.print("Bitte die Kontonummmer für das Zielkonto der Überweisung eingeben: "); int zielkonto = Integer.parseInt(sc.nextLine()); - + System.out.print("Bitte den gewünschten Überweisungsbetrag eingeben: "); double betrag = Double.parseDouble(sc.nextLine()); - + System.out.print("Bitte den Verwendungszweck eingeben: "); String verwendungszweck = sc.nextLine(); - + boolean erfolgreich = bs.überweisungBeauftragen(startkonto, zielkonto, (long)(betrag * 100), verwendungszweck); - + System.out.println("Überweisung" + ( (!erfolgreich) ? " nicht" : "") + " erfolgreich ausgeführt."); }