From 532d329cf8c45e4e057c24f03e6acbf0d8682fd9 Mon Sep 17 00:00:00 2001 From: Peter Gapon Date: Tue, 25 Oct 2022 12:21:11 +0200 Subject: [PATCH] Update --- Bank-Beispiel/object.ser | Bin 334 -> 0 bytes .../de/hs_mannheim/informatik/bank/Main.java | 5 +- .../informatik/bank/domain/Bank.java | 36 ++-- .../informatik/bank/domain/Girokonto.java | 16 +- .../informatik/bank/domain/Konto.java | 90 +++----- .../informatik/bank/domain/KontoTest.java | 55 ++--- .../informatik/bank/domain/Kontobewegung.java | 9 +- .../informatik/bank/facade/Banksystem.java | 122 ++++------- .../bank/facade/BanksystemTest.java | 91 +------- .../bank/infrastructure/Persistenz.java | 30 +++ .../de/hs_mannheim/informatik/bank/ui/UI.java | 197 ++++++------------ .../persistence/PersistenzSerialisiert.java | 48 ----- 12 files changed, 227 insertions(+), 472 deletions(-) delete mode 100644 Bank-Beispiel/object.ser create mode 100644 Bank-Beispiel/src/de/hs_mannheim/informatik/bank/infrastructure/Persistenz.java delete mode 100644 Bank-Beispiel/src/persistence/PersistenzSerialisiert.java diff --git a/Bank-Beispiel/object.ser b/Bank-Beispiel/object.ser deleted file mode 100644 index 61b5d9ad3cc9958928c1c7793103825d7f327804..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 334 zcmZ4UmVvdnh(S0ju`E%qv?Mb}&#|Z|vC=2AxTK=-lI+amiF2757(E$SiZiQHD+(AG z7#Pc0KqOF;eoCrdMsa*@VqRWGYG$rpW?ou;QEp;MX0~2ZVqUghN`7u)W}cpVW>J22 zeqKqwW70aqdA`%_nHU%W3>dC;CSDKrfTI2DE3B{9wzIQp;1*OY_oG^GX;*A<97B t)rWf*sFF1Y= 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 79fd876..16a794f 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java @@ -1,14 +1,11 @@ package de.hs_mannheim.informatik.bank; -import java.io.IOException; - import de.hs_mannheim.informatik.bank.facade.Banksystem; import de.hs_mannheim.informatik.bank.ui.UI; -import exception.BankException; public class Main { - public static void main(String[] args) throws IOException, ClassNotFoundException, BankException { + public static void main(String[] args) throws Exception { Banksystem bs = new Banksystem("Spaßkasse Mannheim"); UI ui = new UI(bs); } 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 c0ef53c..2c0537a 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,42 +1,42 @@ 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<>(); + private int kontozähler; public Bank(String name) { this.name = name; + this.kontozähler = -1; } - public void addKonto(Konto k) { + public int addKonto(String name, int auswahl) { + Konto k; + + if (auswahl == 1) + k = new Konto(name, ++kontozähler); + else + k = new Girokonto(name, ++kontozähler); + konten.put(k.getKontonummer(), k); + + return k.getKontonummer(); } public String getName() { return name; } - public Konto getKonto(int kNummer) { - return konten.get(kNummer); - } - public Collection getKontenliste() { return konten.values(); } - - public void einzahlenBank(int kNummer, long betrag) { - konten.get(kNummer).einzahlenKonto(betrag); + + public Konto findeKonto(int kontonummer) { + return konten.get(kontonummer); } - public void auszahlenBank(int kNummer, long betrag) { - konten.get(kNummer).auszahlenKonto(betrag); - } - - public HashMap getKonten() { - return konten; - } - -} +} \ No newline at end of file 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 fc73dcb..49a8c07 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 @@ -2,18 +2,16 @@ package de.hs_mannheim.informatik.bank.domain; import java.io.Serializable; -import exception.BankException; - public class Girokonto extends Konto implements Serializable { - public Girokonto(String inhaber) { - super(inhaber); + public Girokonto(String inhaber, int kontozähler) { + super(inhaber, kontozähler); } - public boolean überweiseGirokonto(Girokonto ziel, long betrag, String zweck) throws BankException { - if (super.getStand() - betrag >= 0) { - this.auszahlenKonto(betrag, zweck, "Überweisungsausgang", super.getInhaber()); - ziel.einzahlenKonto(betrag, zweck, "Überweisungseingang", super.getInhaber()); + public boolean überweise(Girokonto ziel, long betrag, String zweck) { + if (super.getKontostand() - betrag >= 0) { + this.auszahlen(betrag, zweck, "Überweisungsausgang", super.getInhaber()); + ziel.einzahlen(betrag, zweck, "Überweisungseingang", super.getInhaber()); return true; } @@ -26,4 +24,4 @@ public class Girokonto extends Konto implements Serializable { return "Giro-" + super.toString(); } -} +} \ No newline at end of file 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 9ce1dd0..bae59ab 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 @@ -2,95 +2,65 @@ package de.hs_mannheim.informatik.bank.domain; import java.io.Serializable; import java.util.ArrayList; -import java.util.Date; - -import exception.BankException; public class Konto implements Serializable { - - private static int kontozähler = 0; - private int nummer; private long stand = 0; private String inhaber; - private ArrayList liste = new ArrayList<>(); + private ArrayList kontobewegungen; - public Konto(String inhaber) { - nummer = 1000 + kontozähler++; + public Konto(String inhaber, int kontozähler) { + nummer = 1000 + kontozähler; this.inhaber = inhaber; - + this.kontobewegungen = new ArrayList<>(); } - + public int getKontonummer() { return nummer; } - - public long getStand() { - return stand; + + @Override + public String toString() { + return "Konto [nummer=" + nummer + ", inhaber=" + inhaber + "]"; } public String getInhaber() { return inhaber; } - public void einzahlenKonto(long betrag, String zweck, String art, String auftraggeber) throws BankException { - if (betrag < 0) { - throw new BankException("Betrag darf nicht negativ sein"); - } - this.stand = stand + betrag; - + 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 void auszahlenKonto(long betrag, String zweck, String art, String auftraggeber) throws BankException { - if (this.stand - betrag >= 0) { - this.stand = stand - betrag; - } else { - throw new BankException("Kontostand darf nicht unter 0 sein"); - } - - kontobewegungen.add(new Kontobewegung(betrag, zweck, art, auftraggeber)); - } - - public void kontoauszugErzeugenKonto(long betrag) { - if (betrag > 0) { - Date date = new Date(); - this.liste.add("Datum: " + date + " Betrag: " + betrag); - } else { - Date date = new Date(); - this.liste.add("Datum: " + date + " Betrag: " + betrag); - } - - } - - public void kontoauszugAnzeigenKonto() { - for (String string : this.liste) { - System.out.println(string); + 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 static void setKontozähler(int kontozähler) { - Konto.kontozähler = kontozähler; - } - - public String[] getKontobewgungen() { + public String[] getKontobewegungen() { String[] auflistung = new String[kontobewegungen.size()]; - + int i = 0; for (Kontobewegung kb : kontobewegungen) { auflistung[i++] = kb.toString(); } - + return auflistung; - } - - @Override - public String toString() { - return "Konto [nummer=" + nummer + ", inhaber=" + inhaber + ", stand=" + stand + "]"; - } - -} + +} \ No newline at end of file diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java index af82c47..ceaf07a 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java @@ -1,46 +1,35 @@ package de.hs_mannheim.informatik.bank.domain; -import static org.junit.Assert.assertEquals; import static org.junit.jupiter.api.Assertions.*; -import org.junit.Before; import org.junit.jupiter.api.Test; class KontoTest { - - Konto k1; - Konto k2; - Konto k3; - - @Before - public void vorTest() { -// k1 = new Konto("Anna"); -// k2 = new Konto("Paul"); -// k3 = new Konto("Max"); + @Test + void testKontoBasics() { + Konto k = new Konto("Müller", 0); + assertEquals("Müller", k.getInhaber()); + assertEquals(1000, k.getKontonummer()); + assertEquals(0, k.getKontostand()); } @Test - public void getKontonummerTest() { - k1 = new Konto("Anna"); - k2 = new Konto("Paul"); - k3 = new Konto("Max"); - assertEquals(1003, k1.getKontonummer()); - assertEquals(1004, k2.getKontonummer()); - assertNotEquals(1000, k3.getKontonummer()); - } - - @Test - public void einzahlenTest() { - k1 = new Konto("Anna"); - k2 = new Konto("Paul"); - k3 = new Konto("Max"); - k1.einzahlenKonto(1000); - k2.einzahlenKonto(100); - k3.einzahlenKonto(0); - assertEquals(1000, k1.getStand()); - assertEquals(100, k2.getStand()); - assertEquals(0, k3.getStand()); + void testKontoEinUndAuszahlung() { + Konto k = new Konto("Müller", 0); + Konto k2 = new Konto("Mayer", 1); + + assertEquals("Mayer", k2.getInhaber()); + assertNotEquals(k.getKontonummer(), k2.getKontonummer()); + + k2.einzahlen(100, "Test", "Einzahlung", "JUnit"); + assertEquals(100, k2.getKontostand()); + + assertTrue(k2.auszahlen(50, "Test", "Auszahlung", "JUnit")); + assertEquals(50, k2.getKontostand()); + + assertFalse(k2.auszahlen(500, "Test", "Auszahlung", "JUnit")); + assertEquals(50, k2.getKontostand()); } -} +} \ No newline at end of file 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 5223983..26bfbd8 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 @@ -5,25 +5,24 @@ import java.util.Date; public class Kontobewegung implements Serializable { private long betrag; - private Date date; + private Date datum; private String betreff; private String art; private String auftraggeber; public Kontobewegung(long betrag, String betreff, String art, String auftraggeber) { - super(); this.betrag = betrag; this.betreff = betreff; this.art = art; this.auftraggeber = auftraggeber; - this.date = new Date(); + this.datum = new Date(); } @Override public String toString() { - return "Kontobewegung [betrag=" + betrag + ", date=" + date + ", betreff=" + betreff + ", art=" + art + return "Kontobewegung [betrag=" + betrag + ", datum=" + datum + ", betreff=" + betreff + ", art=" + art + ", auftraggeber=" + auftraggeber + "]"; } -} +} \ No newline at end of file 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 6a68f97..bd0b471 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 @@ -1,116 +1,84 @@ package de.hs_mannheim.informatik.bank.facade; -import java.io.IOException; -import java.util.ArrayList; 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 exception.BankException; -import persistence.PersistenzSerialisiert; +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(bankname)) + this.bank = (Bank) Persistenz.ladeBankDaten(bankname); + else + this.bank = new Bank(bankname); } - - public int kontoAnlegen(String name, int auswahl) throws BankException { - Konto k; + + public int kontoAnlegen(String name, int auswahl) throws Exception { + int kontonummer = bank.addKonto(name, auswahl); - if (auswahl == 1) { - k = new Konto(name); - } else if(auswahl == 2){ - k = new Girokonto(name); - } else { - throw new BankException("Konto nicht angelegt"); - } - - bank.addKonto(k); - - System.out.println(k instanceof Girokonto); - - return k.getKontonummer(); + Persistenz.speichereBankDaten(this.bank, bank.getName()); + + return kontonummer; } 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 Konto getKontoBanksystem(int kNummer) { - return bank.getKonten().get(kNummer); - } - - public void einzahlenBanksystem(int kNummer, long betrag) throws BankException { -// Konto konto = getKontoBanksystem(kNummer); -// konto.einzahlenKonto(betrag, "Einzahlung am Schalter", "Einzahlung", konto.getInhaber()); - bank.getKonten().get(kNummer).einzahlenKonto(betrag, "Einzahlung am Schalter", "Einzahlung", bank.getKonten().get(kNummer).getInhaber()); - } - - public void auszahlenBanksystem(int kNummer, long betrag) throws BankException { - bank.getKonten().get(kNummer).auszahlenKonto(betrag, "Auszahlung am Schalter", "Auszahlung", bank.getKonten().get(kNummer).getInhaber()); - } - - public void kontoauszugErzeugenBanksystem(int kNummer, long betrag) { - bank.getKonten().get(kNummer).kontoauszugErzeugenKonto(betrag); - } - - public void kontoauszugAnzeigenBanksystem(int kNummer) { - bank.getKonten().get(kNummer).kontoauszugAnzeigenKonto(); - } - - public void kontenSpeichern() throws ClassNotFoundException, IOException { - Collection konten = bank.getKontenliste(); - ArrayList liste = new ArrayList<>(); - - - for (Konto k : konten) { - liste.add(k); - } - PersistenzSerialisiert.objectSpeichern(liste); -// bank.addKonto(PersistenzSerialisiert.objectLesen()); -// PersistenzSerialisiert.objectLesen(); - } - - public void kontenLaden() throws ClassNotFoundException, IOException { - ArrayList liste = PersistenzSerialisiert.objectLesen(); + 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, bank.getName()); - for (int i = 0; i < liste.size(); i++) { - bank.addKonto(liste.get(i)); - } - - Konto.setKontozähler(bank.getKontenliste().size()); + return konto.getKontostand(); } - public String[] erstelleKontoauszug(int kNummer) { - Konto konto = bank.getKonto(kNummer); + public boolean geldAuszahlen(int kontonummer, long betrag) throws Exception { + Konto konto = bank.findeKonto(kontonummer); - return konto.getKontobewgungen(); + Persistenz.speichereBankDaten(this.bank, bank.getName()); + + return konto.auszahlen(betrag, "Auszahlung am Schalter", "Auszahlung", konto.getInhaber()); } - public boolean überweisungBeauftragenBanksystem(int startkonto, int zielkonto, long betrag, String verwendungszweck) throws BankException { - Konto start = getKontoBanksystem(startkonto); - Konto ziel = getKontoBanksystem(zielkonto); + 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).überweiseGirokonto((Girokonto)ziel, betrag, verwendungszweck); + return ((Girokonto)start).überweise((Girokonto)ziel, betrag, verwendungszweck); } return false; } -} + + public long getKontostand(int kontonummer) { + Konto konto = bank.findeKonto(kontonummer); + + return konto.getKontostand(); + } + +} \ No newline at end of file diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java index 7b192a1..361ae65 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java @@ -1,92 +1,19 @@ package de.hs_mannheim.informatik.bank.facade; -import static org.junit.jupiter.api.Assertions.*; +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; -import org.junit.Before; import org.junit.jupiter.api.Test; -import de.hs_mannheim.informatik.bank.domain.Konto; -import exception.BankException; - -class BanksystemTest { - - Banksystem bs; - Konto k1; - Konto k2; - Konto k3; - - @Before - public void vorTest() { - bs = new Banksystem("Bank"); - k1 = new Konto("Anna"); - k2 = new Konto("Paul"); - k3 = new Konto("Max"); - } +class SystemTest { @Test - public void kontoAnlegenTest() throws BankException { - bs = new Banksystem("Bank"); - + void smokeTest() throws Exception { + Banksystem bs = new Banksystem("Testsystem"); - assertEquals(1003, bs.kontoAnlegen("Anna", 1)); - assertNotEquals(1000, bs.kontoAnlegen("Paul", 1)); - assertEquals(1005, bs.kontoAnlegen("Max", 1)); - } - -// @Test (expected = RuntimeException.class) -// public void kontoAnlegenTest2() { -// bs = new Banksystem("Bank"); -// -// bs.kontoAnlegen("Anna", 3); -// } - - @Test - public void getKontenlisteTest() throws BankException { - bs = new Banksystem("Bank"); - bs.kontoAnlegen("Anna", 1); - bs.kontoAnlegen("Paul", 1); - - String[] arr = bs.getKontenliste(); - - assertEquals("Konto [nummer=1001, inhaber=Anna, stand=0]", arr[0]); - - } - - @Test - public void getBanknameTest() { - bs = new Banksystem("Bank"); - - assertEquals("Bank", bs.getBankname()); - } - - @Test - public void einzahlenTest() throws BankException { - bs = new Banksystem("Bank"); - bs.kontoAnlegen("Anna", 1); - bs.einzahlenBanksystem(1006, 100); - System.out.println("Test"); - String[] arr = bs.getKontenliste(); - - assertEquals("Konto [nummer=1006, inhaber=Anna, stand=100]", arr[0]); - } - - @Test - public void erstelleKontoauszugTest() throws BankException { - bs = new Banksystem("Bank"); - - bs.kontoAnlegen("Katrin", 1); - bs.einzahlenBanksystem(1000, 100); - String[] test = bs.erstelleKontoauszug(1000); - - for (int i = 0; i < test.length; i++) { - System.out.println(test[i]); - } - assertEquals(1, test.length); - assertEquals("Kontobewegung [betrag=100, date=Sun", test[0].substring(0, 35)); - assertTrue(test[0].contains("betrag=100")); - assertTrue(test[0].contains("betreff=Einzahlung")); - assertTrue(test[0].contains("art=Einzahlung")); - assertTrue(test[0].contains("auftraggeber=Katrin")); + assertNotNull(bs); + assertEquals(0, bs.getKontenliste().length); + assertEquals("Testsystem", bs.getBankname()); } -} +} \ No newline at end of file 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..015a490 --- /dev/null +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/infrastructure/Persistenz.java @@ -0,0 +1,30 @@ +package de.hs_mannheim.informatik.bank.infrastructure; + +import java.io.File; +import java.io.FileInputStream; +import java.io.FileOutputStream; +import java.io.ObjectInputStream; +import java.io.ObjectOutputStream; + +public class Persistenz { + private static final String BANK_DATEI = "-bank-data.ser"; + + public static boolean sindDatenGespeichert(String name) { + return new File(name + BANK_DATEI).exists(); + } + + public static void speichereBankDaten(Object bank, String name) throws Exception { + ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(name + BANK_DATEI)); + oos.writeObject(bank); + oos.close(); + } + + public static Object ladeBankDaten(String name) throws Exception { + ObjectInputStream ois = new ObjectInputStream(new FileInputStream(name + BANK_DATEI)); + Object bank = ois.readObject(); + ois.close(); + + return bank; + } + +} \ No newline at end of file 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 a44b5f8..036df97 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 @@ -1,22 +1,19 @@ package de.hs_mannheim.informatik.bank.ui; -import java.io.IOException; import java.util.Scanner; import de.hs_mannheim.informatik.bank.facade.Banksystem; -import exception.BankException; -import persistence.PersistenzSerialisiert; public class UI { private Banksystem bs; Scanner sc = new Scanner(System.in); - public UI(Banksystem bs) throws IOException, ClassNotFoundException, BankException { + public UI(Banksystem bs) { this.bs = bs; hauptmenü(); } - private void hauptmenü() throws IOException, ClassNotFoundException, BankException { + private void hauptmenü() { System.out.println("Willkommen bei der " + bs.getBankname() + "!"); mainloop: @@ -26,42 +23,35 @@ public class UI { System.out.println("Hauptmenü"); System.out.println("1 -> Konten anzeigen"); System.out.println("2 -> Konto anlegen"); - System.out.println("3 -> Konto einzahlen"); - System.out.println("4 -> Konto auszahlen"); - System.out.println("5 -> Konto anzeigen"); - System.out.println("6 -> Kontoauszug anzeigen"); - System.out.println("7 -> Konten speichern"); - System.out.println("8 -> Konten laden"); - System.out.println("9 -> Kontoauszug drucken"); - System.out.println("10 -> Überweisung beauftragen"); - System.out.println("11 -> Überweisung als Textdatei speichern"); - System.out.println("99 -> Beenden"); + System.out.println("3 -> Geld einzahlen"); + 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(); System.out.print("> "); - int input = 0; - try { - input = Integer.parseInt(sc.nextLine()); - } catch (NumberFormatException e) { -// e.printStackTrace(); - System.err.print("Nur Zahlen eingeben:"); - } + int input = Integer.parseInt(sc.nextLine()); System.out.println(); - switch(input) { - case 1: kontenAnzeigen(); break; - case 2: kontoAnlegen(); break; - case 3: einzahlen(); break; - case 4: auszahlen(); break; - case 5: kontoAnzeigen(); break; - case 6: kontoauszugAnzeigen(); break; - case 7: bs.kontenSpeichern(); break; - case 8: bs.kontenLaden(); break; - case 9: kontoauszugDrucken(); break; - case 10:überweisungBeauftragen(); break; - case 11:kontoauszugSpeichernTxt(); break; - case 99: break mainloop; - } + try { + switch(input) { + case 1: kontenAnzeigen(); 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!"); @@ -80,113 +70,56 @@ public class UI { } } - private void kontoAnzeigen() { - String[] konten = bs.getKontenliste(); - System.out.println("Bitte die Kontonummer des Kontoinhabers angeben: "); - String kName = sc.nextLine(); - - - for (int i = 0; i < konten.length; i++) { - if (konten[i].contains(kName)) { - System.out.println(konten[i]); - break; - } - } - - } - - private void kontoAnlegen() throws BankException { + 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 normales Konto oder ein Girokonto anlegen?"); - System.out.println("Normales Konto 1"); - System.out.println("Girokonto 2"); - int kontoArt = Integer.parseInt(sc.nextLine()); - int kontonummer = bs.kontoAnlegen(name, kontoArt); + System.out.println("Möchten Sie ein Sparkonto (1) oder ein Girokonto (2) anlegen?"); + int auswahl = Integer.parseInt(sc.nextLine()); + + int kontonummer = bs.kontoAnlegen(name, auswahl); System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt."); -// PersistenzSerialisiert.objectSpeichern(bs.getKontoBanksystem(kontonummer)); } - private void einzahlen() throws BankException { - System.out.println("Bitte den Namen des Kontoinhabers angeben: "); - String kName = sc.nextLine(); - String [] konten = bs.getKontenliste(); + 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()); - int temp = 0; - for (int i = 0; i < konten.length; i++) { - if (konten[i].contains(kName)) { - if (konten[i].contains(kName) && konten[i].contains("Giro-Konto")) { - temp = Integer.parseInt(konten[i].substring(19, 23)); - } else { - temp = Integer.parseInt(konten[i].substring(14, 18)); - } - break; - } else { - System.out.println("Konto nicht vorhanden"); - System.out.println("Korrigieren Sie Ihre Eingabe"); - return; - } - } + // optional prüfen, ob Konto existiert - System.out.println("Bitte den gewünschten Betrag eingeben:"); + System.out.print("Bitte den gewünschten Betrag eingeben: "); + double betrag = Double.parseDouble(sc.nextLine()); - long betrag = Long.parseLong(sc.nextLine()); - - bs.einzahlenBanksystem(temp, betrag); - bs.kontoauszugErzeugenBanksystem(temp, betrag); - System.out.println(bs.getKontoBanksystem(temp)); + long neuerKontostand = bs.geldEinzahlen(kontonummer, (long)betrag * 100); + System.out.printf("Einzahlung erfolgreich, neuer Kontostand = %.2f Euro", (neuerKontostand / 100.0)); } - private void auszahlen() throws BankException { - System.out.println("Bitte den Namen des Kontoinhabers angeben: "); - String kName = sc.nextLine(); - String [] konten = bs.getKontenliste(); + 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()); - int temp = 0; - for (int i = 0; i < konten.length; i++) { - if (konten[i].contains(kName)) { - if (konten[i].contains(kName) && konten[i].contains("Giro-Konto")) { - temp = Integer.parseInt(konten[i].substring(19, 23)); - } else { - temp = Integer.parseInt(konten[i].substring(14, 18)); - } - break; - } else { - System.out.println("Konto nicht vorhanden"); - System.out.println("Korrigieren Sie Ihre Eingabe"); - return; - } - } + System.out.print("Bitte den gewünschten Betrag eingeben: "); + double betrag = Double.parseDouble(sc.nextLine()); - System.out.println("Bitte den gewünschten Betrag eingeben:"); + boolean erfolgreich = bs.geldAuszahlen(kontonummer, (long)betrag * 100); - long betrag = Long.parseLong(sc.nextLine()); - - bs.auszahlenBanksystem(temp, betrag); - bs.kontoauszugErzeugenBanksystem(temp, -betrag); - - kontenAnzeigen(); + System.out.printf("Auszahlung" + ((!erfolgreich)? " nicht" : "" )+ " erfolgreich. "); + System.out.printf("Neuer Kontostand = %.2f Euro.", (bs.getKontostand(kontonummer) / 100.0)); } - private void kontoauszugAnzeigen() { - System.out.println("Bitte die Kontonummer des Kontoinhabers angeben: "); - int temp = Integer.parseInt(sc.nextLine()); - System.out.println("Auftraggeber: " + bs.getKontoBanksystem(temp).getInhaber()); - bs.kontoauszugAnzeigenBanksystem(temp); - } - private void kontoauszugDrucken() { - System.out.println("Bitte die gewünschte Kontonummer für den Auszug eingeben: "); - int kNummer = Integer.parseInt(sc.nextLine()); - + System.out.print("Bitte die gewünschte Kontonummer für den Auszug eingeben: "); + int kontonummer = Integer.parseInt(sc.nextLine()); + System.out.println(); - - System.out.println("Auszug für Konto " + kNummer); - String[] kontobewegungen = bs.erstelleKontoauszug(kNummer); - + + // in echt auf einem Drucker + System.out.println("Auszug für Konto " + kontonummer); + String[] kontobewegungen = bs.erstelleKontoauszug(kontonummer); + if (kontobewegungen.length > 0) for (String kb : kontobewegungen) { System.out.println(kb); @@ -194,8 +127,8 @@ public class UI { else System.out.println("Noch keine Kontobewegungen."); } - - private void überweisungBeauftragen() throws BankException { + + private void überweisungBeauftragen() { System.out.print("Bitte die Kontonummer des Ausgangskontos der Überweisung eingeben: "); int startkonto = Integer.parseInt(sc.nextLine()); @@ -208,17 +141,9 @@ public class UI { System.out.print("Bitte den Verwendungszweck eingeben: "); String verwendungszweck = sc.nextLine(); -// boolean erfolgreich = bs.überweisungBeauftragen(startkonto, zielkonto, (long)(betrag * 100), verwendungszweck); - boolean erfolgreich = bs.überweisungBeauftragenBanksystem(startkonto, zielkonto, (long)(betrag), verwendungszweck); + boolean erfolgreich = bs.überweisungBeauftragen(startkonto, zielkonto, (long)(betrag * 100), verwendungszweck); System.out.println("Überweisung" + ( (!erfolgreich) ? " nicht" : "") + " erfolgreich ausgeführt."); } - - private void kontoauszugSpeichernTxt() throws IOException { - System.out.print("Bitte die Kontonummer eingeben die gespeichert werden soll: "); - int kNummer = Integer.parseInt(sc.nextLine()); - - PersistenzSerialisiert.schreibeDatei(bs.erstelleKontoauszug(kNummer)); - } -} +} \ No newline at end of file diff --git a/Bank-Beispiel/src/persistence/PersistenzSerialisiert.java b/Bank-Beispiel/src/persistence/PersistenzSerialisiert.java deleted file mode 100644 index 8a8a822..0000000 --- a/Bank-Beispiel/src/persistence/PersistenzSerialisiert.java +++ /dev/null @@ -1,48 +0,0 @@ -package persistence; -import java.io.File; -import java.io.FileInputStream; -import java.io.FileNotFoundException; -import java.io.FileOutputStream; -import java.io.FileWriter; -import java.io.IOException; -import java.io.ObjectInputStream; -import java.io.ObjectOutputStream; -import java.util.ArrayList; -import de.hs_mannheim.informatik.bank.domain.Konto; - -public class PersistenzSerialisiert { - - public static void main(String[] args) throws Exception { - - } - - public static void objectSpeichern(ArrayList liste) throws IOException { - ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("object.ser")); - - oos.writeObject(liste); - oos.close(); - } - - - - public static ArrayList objectLesen() throws IOException, ClassNotFoundException { - ObjectInputStream ois = new ObjectInputStream(new FileInputStream("object.ser")); - ArrayList liste = (ArrayList) ois.readObject(); - - - ois.close(); - return liste; - } - - public static void schreibeDatei(String[] kontobewegung) throws IOException { - - FileWriter writer = new FileWriter(new File("C:\\Users\\Lenovo\\Desktop\\Kontobewegung.txt")); - - for (int i = 0; i < kontobewegung.length; i++) { - writer.write(kontobewegung[i] + "\n"); - } - - writer.close(); - } - -} \ No newline at end of file