From 1d2b92b87509d01092f140b6701799c1df3ae40b Mon Sep 17 00:00:00 2001 From: User Date: Tue, 25 Oct 2022 13:23:40 +0200 Subject: [PATCH] Testat 2 --- Bank-Beispiel/bank.ser | Bin 813 -> 0 bytes .../de/hs_mannheim/informatik/bank/Main.java | 24 +- .../informatik/bank/domain/Bank.java | 57 ++--- .../informatik/bank/domain/Girokonto.java | 29 ++- .../informatik/bank/domain/Konto.java | 90 +++++--- .../informatik/bank/domain/KontoTests.java | 59 ++++- .../informatik/bank/domain/Kontobewegung.java | 28 ++- .../informatik/bank/facade/Banksystem.java | 82 +++---- .../bank/facade/BanksystemTests.java | 62 ++++- .../bank/infrastructure/Persistenz.java | 30 +++ .../de/hs_mannheim/informatik/bank/ui/UI.java | 214 ++++++++---------- .../informatik/bank/perstance/Datenbank.java | 45 ---- Bank-Beispiel/zähler.ser | Bin 10 -> 0 bytes 13 files changed, 406 insertions(+), 314 deletions(-) delete mode 100644 Bank-Beispiel/bank.ser create mode 100644 Bank-Beispiel/src/de/hs_mannheim/informatik/bank/infrastructure/Persistenz.java delete mode 100644 Bank-Beispiel/src/de/mannheim/informatik/bank/perstance/Datenbank.java delete mode 100644 Bank-Beispiel/zähler.ser diff --git a/Bank-Beispiel/bank.ser b/Bank-Beispiel/bank.ser deleted file mode 100644 index abe9e31e1e75177187d9834e7716928b48967b7d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 813 zcmb7DO=uHQ5T0(bNgHcPQe$bgP`y=QBM2fC{3%kBx)q@wyogS^&)qe*++9do3bmwXEInflX3YG@-QK|)?=xU5K_Q6HS;94n zL>?NJqr>NSSTG=^1IoLnZ#UtYZYwej$@0V8!V*D;7$BA}Rp zrr%wP!v+%%wz{+Xo_>C803QP%H$uDhC|85huLTE@Oefn z%Syk)^cak^vpOpNC;x+ggSD9(bC(;7yF2_9DILp@YcLY%+K@p(DKQ&N2PqB-ru#a` z4_VcY)-bq$#IC67Z(8~~2ntM{opsO)Nb%dBiqadbRVKRE?(ZBrTH7Ai7idqI0Qql) zsi|D?@MiTyLXfQ?mx*R^K konten = new HashMap<>(); - + private int kontozähler; + public Bank(String name) { this.name = name; + this.kontozähler = -1; } + + public int addKonto(String name, int auswahl) { + Konto k; - public void addKonto(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 Collection getKontenliste() { return konten.values(); } - + public Konto findeKonto(int kontonummer) { return konten.get(kontonummer); } - - public void einzahlen(long betrag, int kontonummer) { - if (konten.containsKey(kontonummer)) { - konten.get(kontonummer).einzahlen(betrag, "eingezahlt"); - System.out.println("Betrag " + betrag + " auf Konto " + kontonummer + " eingezahlt"); - System.out.println("Neuer Kontostand: " + konten.get(kontonummer).getKontostand()); - } else - System.out.println("Konto nicht vorhanden"); - } - - public void auszahlen(long betrag, int kontonummer) { - if (konten.containsKey(kontonummer)) { - konten.get(kontonummer).auszahlen(betrag, "ausgezahlt"); - System.out.println("Betrag " + betrag + " auf Konto " + kontonummer + " eingezahlt"); - } else - System.out.println("Konto nicht vorhanden"); - } - - public void kontostandZeigen(int kontonummer) { - if (konten.containsKey(kontonummer)) { - System.out.println("Kontostand: " + konten.get(kontonummer).getKontostand()); - } else - System.out.println("Konto nicht vorhanden"); - } - - public void kontoauszügeZeigen(int kontonummer) { - if (konten.containsKey(kontonummer)) { - for(int i = 0;konten.get(kontonummer).getKontoauszüge().size()> i;i++) { - System.out.println(konten.get(kontonummer).getKontoauszüge().get(i)); - } - } else - System.out.println("Konto nicht vorhanden"); - } -} \ 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 233b108..7b936c9 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,18 +1,27 @@ package de.hs_mannheim.informatik.bank.domain; -public class Girokonto extends Konto { +import java.io.Serializable; - public Girokonto(String inhaber) { - super(inhaber); +public class Girokonto extends Konto implements Serializable { + public Girokonto(String inhaber, int kontozähler) { + super(inhaber, kontozähler); } - - public boolean überweisen(long betrag, Girokonto start, Girokonto ziel, String verwendungszweck) { - if (betrag >= start.getKontostand()) { - start.einzahlen(betrag, "gesendet an " + ziel.getKontonummer()); - ziel.einzahlen(betrag, "empfangen von " + start.getKontonummer()); + + public boolean überweise(Girokonto ziel, long betrag, String zweck) { + if ((super.getKontostand() + super.getDispo()) - betrag >= 0) { + this.auszahlen(betrag, zweck, "Überweisungsausgang", super.getInhaber()); + ziel.einzahlen(betrag, zweck, "Überweisungseingang", super.getInhaber()); + return true; - } else - return false; + } + + return false; } + + @Override + public String toString() { + return "Giro-" + super.toString(); + } + } 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 0957421..d00b386 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 @@ -4,54 +4,84 @@ import java.io.Serializable; import java.util.ArrayList; public class Konto implements Serializable { - private static int kontozähler = 0; - private int nummer; private long stand = 0; private String inhaber; - private ArrayList auszüge = new ArrayList<>(); + private int dispositionskredit = 0; + private int bewegungsZähler = 0; - public Konto(String inhaber) { - nummer = 1000 + kontozähler++; + private ArrayList kontobewegungen; + + public Konto(String inhaber, int kontozähler) { + nummer = 1000 + kontozähler; this.inhaber = inhaber; - } - - public static void ladeKontoZähler(int kontoZähler) { - kontozähler = kontoZähler; + + this.kontobewegungen = new ArrayList<>(); } public int getKontonummer() { return nummer; } - - public static int getKontoZähler() { - return kontozähler; + + @Override + public String toString() { + return "Konto [nummer=" + nummer + ", inhaber=" + inhaber + "]"; } - public void einzahlen(long betrag, String verwendungszweck) { - stand += betrag; - auszüge.add(new Kontobewegung(betrag, inhaber, verwendungszweck)); - } - - public void auszahlen(long betrag, String verwendungszweck) { - if (betrag <= stand) { - stand -= betrag; - auszüge.add(new Kontobewegung(betrag, inhaber, verwendungszweck)); - } else - System.out.println("Kontostand nicht aureichend"); - } - - public ArrayList getKontoauszüge() { - return auszüge; + public String getInhaber() { + return inhaber; } public long getKontostand() { return stand; } + + public void setDispo(int dispowert) { + this.dispositionskredit = dispowert; + } + + public int getDispo() { + return dispositionskredit; + } - @Override - public String toString() { - return "Konto [nummer=" + nummer + ", inhaber=" + inhaber + ", stand=" + stand + "]"; + public void einzahlen(long betrag, String zweck, String art, String auftraggeber) { + stand += betrag; + +// kontobewegungen.add(new Kontobewegung(betrag, zweck, art, auftraggeber)); + speichereKontobewegung(betrag, zweck, art, auftraggeber); + } + + public boolean auszahlen(long betrag, String zweck, String art, String auftraggeber) { + if ((stand + dispositionskredit) - betrag >= 0) { + stand -= betrag; + +// kontobewegungen.add(new Kontobewegung(betrag * -1, zweck, art, auftraggeber)); + speichereKontobewegung(betrag, 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 void speichereKontobewegung(long betrag, String zweck, String art, String auftraggeber) { + bewegungsZähler++; + kontobewegungen.add(new Kontobewegung(betrag, zweck, art, auftraggeber)); + + if(bewegungsZähler % 10 == 0) { + System.out.println("Aktuelles Saldo: " + stand); + } } } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTests.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTests.java index 69615b5..35a3718 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTests.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTests.java @@ -7,17 +7,56 @@ import org.junit.jupiter.api.Test; class KontoTests { @Test - void test() { - Konto k = new Konto("Hans"); - Bank b = new Bank("Sparkasse"); - - b.addKonto(k); - - b.einzahlen(500, k.getKontonummer()); - b.einzahlen(200, k.getKontonummer()); - - assertEquals(700, k.getKontostand()); + void testKontoBasics() { + Konto k = new Konto("Müller", 0); + assertEquals("Müller", k.getInhaber()); + assertEquals(1000, k.getKontonummer()); + assertEquals(0, k.getKontostand()); + } + + @Test + 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()); + } + + @Test + void testDispo() { + Girokonto k1 = new Girokonto("Müller", 0); + Girokonto k2 = new Girokonto("Peter", 1); + + k1.setDispo(500); + + k1.einzahlen(1000, "Test", "Einzahlung", "JUnit"); + k1.auszahlen(1300, "Test", "Auszahlung", "JUnit"); + + assertEquals(-300, k1.getKontostand()); + + assertFalse(k1.auszahlen(300, "Test", "Auszahlung", "JUnit")); + + assertFalse(k1.überweise(k2, 300, "Test")); + } + + @Test + void testSaldo() { + Konto k = new Konto("Müller", 0); + + for(int i = 0; i < 10;i++) { + System.out.println(i); + k.einzahlen(10, "Test", "Einzahlung", "JUnit"); + } } } 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 2a0c463..2026293 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,24 +1,28 @@ package de.hs_mannheim.informatik.bank.domain; import java.io.Serializable; -import java.time.LocalDateTime; +import java.util.Date; public class Kontobewegung implements Serializable { private long betrag; - private String inhaber; - private LocalDateTime datum; + private Date datum; + private String betreff; private String art; - - public Kontobewegung(long betrag, String inhaber, String art) { - this.betrag = betrag; - this.inhaber = inhaber; - this.art = art; - - datum = LocalDateTime.now(); - } + private String auftraggeber; + public Kontobewegung(long betrag, String betreff, String art, String auftraggeber) { + this.betrag = betrag; + this.betreff = betreff; + this.art = art; + this.auftraggeber = auftraggeber; + + this.datum = new Date(); + } + @Override public String toString() { - return "Betrag " + betrag + " wurde am " + datum + " " + art; + return "Kontobewegung [betrag=" + betrag + ", datum=" + datum + ", betreff=" + betreff + ", art=" + art + + ", auftraggeber=" + auftraggeber + "]"; } + } 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 5059f50..109ac25 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,42 +5,24 @@ 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.mannheim.informatik.bank.perstance.Datenbank; +import de.hs_mannheim.informatik.bank.infrastructure.Persistenz; public class Banksystem { private Bank bank; public Banksystem(String bankname) throws Exception { - if (Datenbank.sindDateGespeicher()) { - this.bank = (Bank) Datenbank.laden(); - Konto.ladeKontoZähler(Datenbank.ladeKontoZähler()); - } else + if (Persistenz.sindDatenGespeichert(bankname)) + this.bank = (Bank) Persistenz.ladeBankDaten(bankname); + else this.bank = new Bank(bankname); } - public int kontoAnlegen(String name, int auswahl) { - 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 - k = new Girokonto(name); // Hier eigentlich Girokonto + Persistenz.speichereBankDaten(this.bank, bank.getName()); - bank.addKonto(k); - - return k.getKontonummer(); - } - - public void einzahlen(long betrag, int kontonummer) { - bank.einzahlen(betrag, kontonummer); - } - - public void auszahlen(long betrag, int kontonummer) { - bank.auszahlen(betrag, kontonummer); - } - - public void kontostandZeigen(int kontonummer) { - bank.kontostandZeigen(kontonummer); + return kontonummer; } public String[] getKontenliste() { @@ -55,27 +37,49 @@ public class Banksystem { return liste; } - public void kontoauszügeZeigen(int kontonummer) { - bank.kontoauszügeZeigen(kontonummer); - } - public String getBankname() { return bank.getName(); } - public boolean überweisen(int sender, int empfänger, long betrag, String verwendungszweck) { - Konto start = bank.findeKonto(sender); - Konto ziel = bank.findeKonto(empfänger); - - if(start instanceof Girokonto && ziel instanceof Girokonto) { - Girokonto.überweisen(betrag, (Girokonto)start, (Girokonto)ziel, verwendungszweck); + 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()); + + return konto.getKontostand(); + } + + public boolean geldAuszahlen(int kontonummer, long betrag) throws Exception { + Konto konto = bank.findeKonto(kontonummer); + + Persistenz.speichereBankDaten(this.bank, bank.getName()); + + 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 void speichern() throws Exception { - Datenbank.speichern(bank); - Datenbank.speicherZähler(Konto.getKontoZähler()); + public long getKontostand(int kontonummer) { + Konto konto = bank.findeKonto(kontonummer); + + return konto.getKontostand(); } + } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTests.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTests.java index d978a05..2d26c08 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTests.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTests.java @@ -1,12 +1,68 @@ package de.hs_mannheim.informatik.bank.facade; -import static org.junit.jupiter.api.Assertions.*; +import static org.junit.Assert.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertEquals; + +import java.io.File; import org.junit.jupiter.api.Test; -class BanksystemTests { +import de.hs_mannheim.informatik.bank.infrastructure.Persistenz; + +class BanksystemTest { @Test - void einzahlenTest() { + void smokeTest() throws Exception { + Banksystem bs = new Banksystem("Testsystem"); + + assertNotNull(bs); + assertEquals(0, bs.getKontenliste().length); + assertEquals("Testsystem", bs.getBankname()); + } + + @Test + void einzahlenTest() throws Exception { + Banksystem bs = new Banksystem("Testsystem"); + + bs.kontoAnlegen("TestUser", 0); + + bs.geldEinzahlen(1000, 1000); + + assertEquals(1000, bs.getKontostand(1000)); + + bs.geldAuszahlen(1000, 200); + + assertEquals(800, bs.getKontostand(1000)); + + bs.geldEinzahlen(1000, 500); + + assertEquals(1300, bs.getKontostand(1000)); + + File save = new File("C:/Users/User/git/Bank-System_Hummel/Bank-Beispiel/Testsystem-bank-data.ser"); + + System.out.println(save.exists()); + + Banksystem testBank = new Banksystem("Testsystem"); + + assertEquals(1300, testBank.getKontostand(1000)); + } + +// @Test +// void persistenzTest() throws Exception { +// Banksystem testBank = new Banksystem("Testsystem"); +// +// assertEquals(1300, testBank.getKontostand(1000)); +// +// System.out.println(testBank.getBankname()); +// +// } + + @Test + void dateiLöschen2() { + File save = new File("C:/Users/User/git/Bank-System_Hummel/Bank-Beispiel/Testsystem-bank-data.ser"); + + save.exists(); + save.delete(); + } } 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..967db12 --- /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 57e5f74..fa0450c 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 @@ -2,94 +2,66 @@ package de.hs_mannheim.informatik.bank.ui; import java.util.Scanner; -import de.hs_mannheim.informatik.bank.domain.Bank; import de.hs_mannheim.informatik.bank.facade.Banksystem; -import de.mannheim.informatik.bank.perstance.Datenbank; public class UI { private Banksystem bs; Scanner sc = new Scanner(System.in); - public UI(Banksystem bs) throws Exception { + public UI(Banksystem bs) { this.bs = bs; - hauptmenu(); - bs.speichern(); + hauptmenü(); } - private void hauptmenu() { + private void hauptmenü() { System.out.println("Willkommen bei der " + bs.getBankname() + "!"); - mainloop: while (true) { - System.out.println(); - System.out.println("--------"); - System.out.println("Hauptmenü"); - System.out.println("1 -> Konten anzeigen"); - System.out.println("2 -> Konto anlegen"); - System.out.println("3 -> Geld einzahlen"); - System.out.println("4 -> Geld auszahlen"); - System.out.println("5 -> Kontostand anzeigen"); - System.out.println("6 -> Kontoauszüge zeigen"); - System.out.println("7 -> Überweisung tätigen"); - System.out.println("9 -> Beenden"); - System.out.println(); + mainloop: + while (true) { + System.out.println(); + System.out.println("--------"); + System.out.println("Hauptmenü"); + System.out.println("1 -> Konten anzeigen"); + System.out.println("2 -> Konto anlegen"); + 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.print("> "); - int input = Integer.parseInt(sc.nextLine()); - System.out.println(); + System.out.println("9 -> Beenden"); + System.out.println(); - switch (input) { - case 1: - kontenAnzeigen(); - break; - case 2: - kontoAnlegen(); - break; - case 3: - einzahlen(); - break; - case 4: - auszahlen(); - break; - case 5: - kontostandZeigen(); - break; - case 6: - kontoauszügeZeigen(); - break; - case 7: - überweisen(); - break; - case 9: - break mainloop; + System.out.print("> "); + int input = Integer.parseInt(sc.nextLine()); + System.out.println(); + + 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!"); - } // hauptmenü + } // - private void überweisen() { - int kontonummer; - int empfänger; - long betrag; - String verwendungszweck; - - System.out.println("Kontonummer eingeben: "); - kontonummer = Integer.parseInt(sc.nextLine()); - System.out.println("Kontonummer des Empfängers eingeben: "); - empfänger = Integer.parseInt(sc.nextLine()); - System.out.println("Betrag eingeben: "); - betrag = Integer.parseInt(sc.nextLine()); - System.out.println("Verwendungszweck eingeben: "); - verwendungszweck = sc.nextLine(); - - bs.überweisen(kontonummer, empfänger, betrag, verwendungszweck); - } - - private void kontenAnzeigen() { + private void kontenAnzeigen() { String[] konten = bs.getKontenliste(); if (konten.length > 0) { - System.out.println("Folgende Konten sind aktuell verfügbar:"); + System.out.println("Folgende Konten sind aktuell verfügbar:"); for (String s : konten) { System.out.println(s); } @@ -98,66 +70,80 @@ 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 oder Girokonto anlegen?"); + + 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."); } - private void einzahlen() { - int kontonummer; - long betrag; + 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()); - try { - System.out.print("Kontonummer eingeben: "); - kontonummer = Integer.parseInt(sc.nextLine()); - System.out.print("Betrag eingeben: "); - betrag = Integer.parseInt(sc.nextLine()); - bs.einzahlen(betrag, kontonummer); - } catch (Exception e) { - System.out.println("Fehlerhafte Eingabe!"); - } + // 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 auszahlen() { - int kontonummer; - long betrag; + 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()); - try { - System.out.print("Kontonummer eingeben: "); - kontonummer = Integer.parseInt(sc.nextLine()); - System.out.print("Betrag eingeben: "); - betrag = Integer.parseInt(sc.nextLine()); - bs.auszahlen(betrag, kontonummer); - } catch (Exception e) { - System.out.println("Fehlerhafte Eingabe"); - } + 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 kontostandZeigen() { - int kontonummer; - try { - System.out.print("Kontonummer eingeben: "); - kontonummer = Integer.parseInt(sc.nextLine()); - bs.kontostandZeigen(kontonummer); - } catch (Exception e) { - System.out.println("Fehlerhafte Eingabe"); - } + 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); + + if (kontobewegungen.length > 0) + for (String kb : kontobewegungen) { + System.out.println(kb); + } + else + System.out.println("Noch keine Kontobewegungen."); } - private void kontoauszügeZeigen() { - int kontonummer; - try { - System.out.print("Kontonummer eingeben: "); - kontonummer = Integer.parseInt(sc.nextLine()); - bs.kontoauszügeZeigen(kontonummer); - } catch (Exception e) { - System.out.println("Fehlerhafte Eingabe"); - } + 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."); } -} \ No newline at end of file + +} diff --git a/Bank-Beispiel/src/de/mannheim/informatik/bank/perstance/Datenbank.java b/Bank-Beispiel/src/de/mannheim/informatik/bank/perstance/Datenbank.java deleted file mode 100644 index 7d4c007..0000000 --- a/Bank-Beispiel/src/de/mannheim/informatik/bank/perstance/Datenbank.java +++ /dev/null @@ -1,45 +0,0 @@ -package de.mannheim.informatik.bank.perstance; - -import de.hs_mannheim.informatik.bank.domain.Bank; - -import java.io.*; - -public class Datenbank { - private static final String saveBank = "bank.ser"; - private static final String saveZähler = "zähler.ser"; - - public static boolean sindDateGespeicher() { - return new File(saveBank).exists(); - } - - public static void speichern(Bank bank) throws Exception { - ObjectOutputStream fileOut; - fileOut = new ObjectOutputStream(new FileOutputStream(saveBank)); - fileOut.writeObject(bank); - fileOut.close(); - } - - public static void speicherZähler(int kontoZähler) throws Exception { - ObjectOutputStream fileOut; - fileOut = new ObjectOutputStream(new FileOutputStream(saveZähler)); - fileOut.writeInt(kontoZähler); - fileOut.close(); - } - - public static Object laden() throws Exception { - ObjectInputStream fileIn; - fileIn = new ObjectInputStream(new FileInputStream(saveBank)); - Object bank = fileIn.readObject(); - fileIn.close(); - - return bank; - } - - public static int ladeKontoZähler() throws Exception { - ObjectInputStream fileIn; - fileIn = new ObjectInputStream(new FileInputStream(saveZähler)); - int kontoZähler = fileIn.readInt(); - fileIn.close(); - return kontoZähler; - } -} diff --git a/Bank-Beispiel/zähler.ser b/Bank-Beispiel/zähler.ser deleted file mode 100644 index 6725d0f9f87e1d87f28a50cc23c96a1125cd4405..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10 RcmZ4UmVvdLg@J*A2>=or0vrGU