1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
|
Allgemeines
-----------
Die Passport-Variante SIZRDHFile kann benutzt werden, um Schlüsseldateien,
die von anderer HBCI-Software erzeugt wurden, mit HBCI4Java zu benutzen.
Dabei wird zur Zeit Software unterstützt, welche auf dem SIZ-HBCI-Kernel
basiert. Bisher wurden erfolgreich Dateien von StarMoney und GENOlite
eingelesen, es ist aber sehr wahrscheinlich, dass es noch mehr Software gibt,
mit der es funktioniert. Wenn jemand Schlüsseldisketten anderer Software
außer der o.g. erfolgreich benutzen kann, bitte eine kurze Mitteilung an mich.
Installation
------------
Für die Verwendung dieser Passport-Klasse muss von die SIZ-RDH-Bibliothek heruntergeladen
und installiert werden. Die in diesem Paket enthaltene Bibliothek für die
jeweilige Plattform wird in ein beliebiges Verzeichnis kopiert.
Der vollständige Dateiname (mit Pfadangabe) dieser Bibliothek muss
vor der Initialisierung des SIZRDHFile-Passports im HBCI-Parameter
client.passport.SIZRDHFile.libname angegeben werden.
Verwendung
----------
Möglichkeit 1)
SIZRDHFile-Passports sind dazu gedacht, Schlüsseldateien anderer HBCI-Software
*parallel* zu dieser Software mit HBCI4Java zu benutzen. Das heisst, dass
HBCI4Java Daten aus der Schlüsseldatei liest und auch wieder hineinschreibt.
Dieser Vorgang ist relativ kritisch, weil einige Softwareprodukte neben
den mir bekannten Daten möglicherweise zusätzliche Informationen in der
Schlüsseldatei ablegen, die durch den HBCI4Java-Schreibvorgang überschrieben
oder ungültig gemacht werden könnten. Dieses Vorgehen hat aber den Vorteil,
dass ein und die selbe Schlüsseldatei sowohl mit HBCI4Java als auch
mit der anderen Software verwendet werden kann, ohne dass irgendwelche
manuellen Konvertierungen nötig wären.
Möglichkeit 2)
Soll jedoch eine existierende SIZ-RDH-Schlüsseldatei *nur noch* mit HBCI4Java
benutzt werden, so ist eine Konvertierung dieser Datei in das RDHNew-Dateiformat
zu empfehlen. Dazu kann entweder das Tool org.kapott.hbci.tools.ConvertSIZRDHPassport
(ist in HBCI4Java enthalten) oder der separat erhältliche HBCI4Java Passport Editor
verwendet werden. Die Konvertierung von RDHNew-Dateien in SIZ-RDH-Schlüsseldateien
ist ebenfalls geplant.
Aktueller Stand
---------------
Im Moment können SIZ-Schlüsseldatei sowohl eingelesen als auch geschrieben
werden. Dabei gibt es aber einige Details zu beachten:
1) SIZ-Dateien können nicht initial erzeugt werden. Das heißt, es ist nicht möglich,
mit HBCI4Java eine SIZ-Schlüsseldatei *anzulegen*, wenn sie noch nicht existiert.
Es ist nur möglich, bereits existierende und initialisierte(!) Schlüsseldateien
zu verwenden.
2) Beim Zurückschreiben von SIZ-Schlüsseldateien werden noch nicht wirklich alle
in der Datei gespeicherten Daten mit den aktuellen Werten überschrieben. Solche
Daten sollten also mit HBCI4Java auch nicht verändert werden.
Konkret heißt das, dass bei Verwendung von SIZ-Schlüsseldateien keine Schlüssel-
änderungen oder -sperrungen durchgeführt werden können, außerdem darf weder
die Nutzerkennung, die Bankverbindung oder die Adresse des HBCI-Servers geändert
werden (das Ändern selbst funktioniert für ein konkretes Passport-Objekt, nur
werden die geänderten Daten nicht in die Schlüsseldatei zurückgeschrieben, so
dass beim nächsten Laden der Datei wieder die alten Daten da sind --- vor allem
bei Schlüsseln ist das natürlich fatal!)
Prinzipiell können in einer SIZ-RDH-Schlüsseldatei Informationen über mehrere
HBCI-Zugänge abgespeichert werden. Solche Schlüsseldateien mit mehreren Einträgen
werden von HBCI4Java ebenfalls unterstützt. Beim Laden einer solchen Schlüsseldatei
wird ein Callback erzeugt, der von alle enthaltenen Einträgen die Bankleitzahl und
die Benutzerkennung "anzeigt" und als Rückgabewert die Auswahl eines dieser
Einträge erwartet (siehe dazu HBCICallback.NEED_SIZENTRY_SELECT). Der so ausgewählte
Eintrag wird dann für die Erzeugung des Passport-Objektes verwendet, alle
anderen in der Datei vorhandenen Einträge werden ignoriert.
Enthält die Datei tatsächlich nur einen einzigen Eintrag mit HBCI-Zugangsdaten,
so wird dieser Eintrag automatisch (ohne die Erzeugung eines Callbacks) benutzt.
Viel Spass beim Testen und Bugreports schreiben...
-Stefan-
|