Schnittstellenmodule automatisch erstellen (JAXB)

vorhergehende Artikel in: Java dWb+ Komponenten
25.01.2015

In einem früheren Artikel wurden verschiedene Gedankenexperimente durchgespielt, die alle unter einem Motto standen: Wie lässt sich für Anwender von dWb+ am unkompliziertesten die Erstellung spezifischer Schnittstellenmodule realisieren? Hier der erste konkrete Vorschlag dazu:

Dataflow Workbench dWb+ Es wurde eine Möglichkeit geschaffen, die Kopplung zu Systemen, die Daten per XML zur Verfügung stellen, bzw konsumieren, zu vereinfachen. Diese Möglichkeit setzt voraus, daß die über die Schnittstelle ausgetauschten Daten über ein XML Schema definiert sind.

Dazu wurde die Technologie JAXB benutzt und darauf aufbauend ein Projekt erstellt, das in der Lage ist, aus einem XML-Schema die Klassen für das Mapping Java<->XML zu erstellen. Anschließend geht das Projekt einen Schritt weiter: zu jeder der Klassen, die als Entsprechungen der Typen im XML-Schema erstellt wurden, wird ein dWb+-Modul erstellt, das in der Lage ist, eine Instanz des jeweiligen Typs aus einer DOM-Struktur oder einem String zu erzeugen.

Für die Serialisierung eines der Typen in einen String, bzw eine DOM-Stuktur stehen dWb+-Module zur Verfügung.

Um die Rohdaten in den Workspace einzuleiten, stehen verschiedenste Module zur Verfügung. Mit den bereits bestehenden Mitteln sind dazu als Schnittstellen unter anderem Dateien, Sockets, eine HTTP-Verbindung oder JMS-Queues und Topics bereits verfügbar. Von dort können die Daten dann mittels der durch das Projekt erzeugten Module in Datenobjekte umgewandelt werden, die andere Module manipulieren können. Resultierende Datenobjekte können nach XML-Strings serialisiert ebenfalls wieder über die breite Palette an Schnittstellenmodulen aus dWb+ an Drittsysteme übergeben werden.

Zur Benutzung des Projekts ist das unten angehängte Archiv zu entpacken. Anschließend muß die Datei namens build.properties noch angepasst werden:

interface.xmlschema=schema.xsd
interface.package=changeme
dWb.libraries.dir=<install directory of dWb+>/jars
interface.xmlschema
Name und voller Dateipfad zum XML Schema Dokument
interface.package
Name des Paketes für die generierten Module und Mappings
dWb.libraries.dir
Name des Unterverzeichnisses namens jars im Installationverzeichnisses der Anwendung dWb+ (komplett mit vollständigem Pfad und einschließlich des Bestandteils jars)

Lizenz
projekt

Artikel, die hierher verlinken

Javascript-Schnittstellen in dWb+

31.01.2015

In einem früheren Artikel wurden verschiedene Gedankenexperimente durchgespielt, die alle unter einem Motto standen: Wie lässt sich für Anwender von dWb+ am unkompliziertesten die Erstellung spezifischer Schnittstellenmodule realisieren? Nach dem ersten nun hier der zweite konkrete Vorschlag dazu:

Alle Artikel rss Wochenübersicht Monatsübersicht Codeberg Repositories Mastodon Über mich home xmpp


Vor 5 Jahren hier im Blog

  • Vorhaben 2020

    03.01.2020

    Genau wie letztes Jahr habe ich auch dieses Jahr wieder ein "Listche" verfasst, um mir all die interessanten Vorhaben zu notieren, die ich mit mittlerem zeitlichen Horizont anzugehen gedenke.

    Weiterlesen...

Neueste Artikel

  • Migration der Webseite und aller OpenSource Projekte

    In eigener Sache...

    Weiterlesen...
  • 38c3 - Nachlese

    Nach dem ersten Teil von mir als interessant eingestufter Vorträge des Chaos Communication Congress 2024 hier nun die Nachlese

    Weiterlesen...
  • 38c3 - Empfehlungen

    Nach dem So - wie auch im letzten Jahr: Meine Empfehlungen für Vorträge vom Chaos Communication Congress 2024 - vulgo: 38c3:

    Weiterlesen...

Manche nennen es Blog, manche Web-Seite - ich schreibe hier hin und wieder über meine Erlebnisse, Rückschläge und Erleuchtungen bei meinen Hobbies.

Wer daran teilhaben und eventuell sogar davon profitieren möchte, muss damit leben, daß ich hin und wieder kleine Ausflüge in Bereiche mache, die nichts mit IT, Administration oder Softwareentwicklung zu tun haben.

Ich wünsche allen Lesern viel Spaß und hin und wieder einen kleinen AHA!-Effekt...

PS: Meine öffentlichen Codeberg-Repositories findet man hier.