Reporting mit Jaspersoft

Daten bestmöglich und in erster Linie benutzerfreundlich zu präsentieren, ist ein wichtiger Anspruch an unsere Produkte. Oft ist es zusätzlich notwendig die Daten in einer bestimmten Weise zu exportieren, für Bilanzen, Statistiken oder andere zusammenfassende Berichte. Altlast4Web bot schon von Anfang an die Möglichkeit, die umfassenden Daten zu belasteten Standorten in einem vorgegebenen Layout generalisiert in Dokumenten mit unterschiedlichen Export-Formaten wiederzugeben. Nicht nur um die Kundenanforderungen abzudecken, sondern auch um noch mehr Flexibilität bei der Darstellung zu erreichen, setzen wir seit letzem Jahr TIBCO Jaspersoft ein.

Mit Jaspersoft lassen sich Reports auf den Pixel genau formatieren, fliessende Seitenübergänge oder Lücken bei leeren Datengrundlage stellen kein Problem mehr da. Die Handhabung ist einfach und benötigt keine Programmierkenntnisse. Wer lieber im Code designed, kann die XML Datei direkt anpassen.  Mit TIBCO Jaspersoft Studio lassen sich Reports über die benutzerfreundliche GUI direkt in der Dokumentenansicht oder im Source Code schnell und einfach generieren.

Links Design Ansicht in Jaspersoft Studio, rechts der finale Export mit Testdaten aus unserer Altlast4Web Demo Anwendung.

Für unsere Anforderungen war die Karteneinbindung über einen URL-Link bislang die geeigneteste Lösung. Mapserver und entsprechende Dienste waren bereits eingerichtet. Extent und andere Parameter konnten spezifisch konfiguriert werden.

Im xml-Code sieht die Einbindung folgendermaßen aus:

<image>
    <reportElement mode="Transparent" x="60" y="60" width="440" height="440" uuid="7722cce9-ad6f-40aa-ad99-a92b01485c17">
    </reportElement>
    <imageExpression><![CDATA[$F{kbs_url}]]></imageExpression>
</image>

Beispiel für eine $F{kbs_url}:

https://[my server]/cgi-bin/altlast4web.wms?&LAYERS=KBS&SRS=EPSG%3A2056&FORMAT=image%2Fpng&USER=18&SERVICE=WMS&VERSION=1.1.1&REQUEST=GetMap&STYLES=&EXCEPTIONS=application%2Fvnd.ogc.se_inimage&TRANSPARENT=TRUE&VFLZ=7022122&BBOX=2635694.8198570926,1245879.5853543915,2636544.8198570926,1246607.5853543915&WIDTH=1000&HEIGHT=1000

Prinzipiell ist es möglich, auch einfach zwei Bilder übereinanderzulegen:

<image>
    <reportElement mode="Transparent" x="60" y="60" width="440" height="440" uuid="7722cce9-ad6f-40aa-ad99-a92b01485c17">
    </reportElement>
    <imageExpression><![CDATA[$F{kbs_url}]]></imageExpression>
</image>
<image>
    <reportElement mode="Transparent" x="60" y="60" width="440" height="440" uuid="77a3c12b-aea9-41b3-9c06-081f4ba70fd5"/>
    <imageExpression><![CDATA[$F{background_url}]]></imageExpression>
</image>

Allerdings wird diese Einstellung nicht korrekt im Word-Export übernommen, weshalb wir dazu raten sich auf eine URL zu begrenzen. Wir konnten dieses Problem ganz einfach über unseren Mapserver lösen, indem wir den externen Kartendienst in unseren eingebunden haben. Damit bleibt es eine URL mit mehreren Layern die angefragt werden:

https://[my server]/cgi-bin/altlast4web.wms?&LAYERS=ch_swisstopo_swissimage,KBS&SRS=EPSG%3A2056&FORMAT=image%2Fpng&USER=18&SERVICE=WMS&VERSION=1.1.1&REQUEST=GetMap&STYLES=&EXCEPTIONS=application%2Fvnd.ogc.se_inimage&TRANSPARENT=TRUE&VFLZ=7022122&BBOX=2635694.8198570926,1245879.5853543915,2636544.8198570926,1246607.5853543915&WIDTH=1000&HEIGHT=1000

Integration der Reports in unsere Anwendungen

Wir nutzen TIBCO JasperReports Server innerhalb eines Docker-Containers, um die Reportdateien (.jrxml) in unsere Anwendungen einzubinden. Über die Benutzeroberfläche von Jasper Server lässt sich die Datenbankverbindung und die Reports, samt eventueller Reportparameter konfigurieren. Unsere Anwendungen greifen per URL-Aufruf auf die einzelnen Reports zu.

Jasper Server lässt sich nicht zuletzt auch wegen der schnellen Konfigurierung mit eigenem Corporate Design in einer css-Datei bestmöglich in unsere Anwendungen einbetten.

Jasper Studio Ansicht mit den hinterlegten Reports und dem Corporate Design von geOps.

Fazit

Die Reportgenerierung mit Jaspersoft bietet viele Möglichkeiten. Nach dem Einstieg sind Reports einfach zu Strukturieren. Vor allem die codebasierte Bearbeitung in Kombination mit Vorschau-Option vereinfacht das Entwickeln. Jedoch kommt es vor, dass man hin und wieder an ungenauen Fehlermeldungen hängen bleibt. Jasper Server liefert meist nicht lesbare Error-IDs, obwohl die genaue Meldung in den Server Logs zu finden ist.

Insgesamt sind wir beeindruckt, wie schnell Anpassungen an den Reports direkt publiziert werden können. Jaspersoft wird uns zukünftig noch in weiteren Anwendungen unterstützen und wir freuen uns darauf, weitere bisher ungenutzte Features und Möglichkeiten der Reportgenerierung auszuschöpfen.

geschrieben von Elke Erhardt | 9.2.2023
Mehr zum Thema
3 min Lesezeit | Blog

performance.now()

Zwei Frontend-Entwickler von geOps machten sich nach Amsterdam auf, um an der performance.now() teilzunehmen, einer zweitägigen Konferenz mit vierzehn erstklassigen Sessions, die die wichtigsten Erkenntnisse zur Web-Performance von heute behandeln.

weiterlesen
6 min Lesezeit | Blog

Webkarten als PDF exportieren und drucken

Schon seit einiger Zeit bieten einige unserer Apps den Export unserer Karten im PDF-Format. Dieser Artikel stellt unsere Lösungen für diverse Neuerungen dieser Funktion vor.

weiterlesen
9 min Lesezeit | Blog

Snapping stops to vehicle trajectories

How to snap points to a line string in a given order and what it has to do with quality assurance when importing public transport schedules.

weiterlesen
7 min Lesezeit | Blog

Using Redis Subscriptions efficiently in Python

Inspired by the websockets broadcast feature we built a subscription multiplexer for redis subscriptions to subscribe to Redis channels and patterns once for all relevant clients.

weiterlesen
2 min Lesezeit | Blog

GraphQL - Hackathon 2022

Mitglieder des geOps-Entwicklerteams erforschen GraphQL in einem internen Hackathon, um dessen Potenzial für geOps-Projekte zu entdecken.

weiterlesen
2 min Lesezeit | Blog

Von Backend bis Frontend: wir suchen Verstärkung

Wir bieten zwei Stellen als Fullstack- oder Backend-Entwickler:innen für unsere Offices in Freiburg und Olten. Wenn du deine Leidenschaft in einem starken Team einbringen willst, dann solltest du dich bewerben.

weiterlesen

Kontakt

geOps AG
Solothurnerstrasse 235
CH-4600 Olten

fon: +41 61 588 05 05
mail: info@geops.ch
geOps GmbH
Bismarckallee 10
D-79098 Freiburg im Breisgau

fon: +49 761 458 925 0
mail: info@geops.de
Impressum | Datenschutz | Bedingungen