Java-Adapter

improve this page | report issue

Übersicht

Java-Adapter basieren auf der Spezifikation JAX-RS 2.0. Ein Java-Adapter ist also ein JAX-RS-2.0-Service, der ohne großen Aufwand in einer Instanz von MobileFirst Server implementiert werden kann und auf MobileFirst-Server-APIs sowie APIs anderer Anbieter zugreifen kann.

Voraussetzung: Arbeiten Sie zuerst das Lernprogramm Java- und JavaScript-Adapter erstellen durch.

Fahren Sie mit folgenden Abschnitten fort:

Dateistruktur

mvn-adapter

Ordner ‘adapter-resources’

Der Ordner adapter-resources enthält eine XML-Konfigurationsdatei (adapter.xml). In dieser Konfigurationsdatei können Sie den Klassennamen der JAX-RS-2.0-Anwendung für diesen Adapter definieren, z. B. com.sample.JavaAdapterApplication.

<?xml version="1.0" encoding="UTF-8"?>
<mfp:adapter name="JavaAdapter"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns:mfp="http://www.ibm.com/mfp/integration"
	xmlns:http="http://www.ibm.com/mfp/integration/http">

	<displayName>JavaAdapter</displayName>
	<description>JavaAdapter</description>

	<JAXRSApplicationClass>com.sample.JavaAdapterApplication</JAXRSApplicationClass>
	
	<property name="DB_url" displayName="Database URL" defaultValue="jdbc:mysql://127.0.0.1:3306/mobilefirst_training"  />
	<property name="DB_username" displayName="Database username" defaultValue="mobilefirst"  />
	<property name="DB_password" displayName="Database password" defaultValue="mobilefirst"  />
<securityCheckDefinition name="sample" class="com.sample.sampleSecurityCheck">
    	<property name="maxAttempts" defaultValue="3"/>
	</securityCheckDefinition>
</mfp:adapter>
  • name: Dieses obligatorische Attribut gibt den Namen des Adapters an. Dieser Name muss innerhalb von MobileFirst Server eindeutig sein. Er kann aus alphanumerischen Zeichen und Unterstreichungszeichen bestehen und muss mit einem Buchstaben beginnen. Den Namen eines definierten und implementierten Adapters können Sie nicht mehr ändern.
  • displayName: Dieses optionale Attribut gibt den Namen des Adapters an, der in der MobileFirst Operations Console angezeigt wird. Wenn dieses Element nicht angegeben ist, wird stattdessen der Wert des Attributs name verwendet.
  • description: Dieses optionale Attribut gibt zusätzliche Informationen zum Adapter an. Die Informationen werden in der MobileFirst Operations Console angezeigt.
  • JAXRSApplicationClass: Dieses Attribut, das obligatorisch ist, um einen Endpunkt /adapter zugänglich zu machen, definiert den Klassennamen der JAX-RS-Anwendung für diesen Adapter. Im Beispiel lautet der Name com.sample.JavaAdapterApplication.
  • securityCheckDefinition: Dieses optionale Attribut definiert ein Sicherheitsprüfungsobjekt. Weitere Informationen zu Sicherheitsüberprüfungen enthält das Lernprogramm Sicherheitsüberprüfungen erstellen.
  • property: Dieses optionale Attribut deklariert eine benutzerdefinierte Eigenschaft. Weitere Informationen hierzu enthält der folgende Abschnitt.

Angepasste Eigenschaften

Die Datei adapter.xml kann auch benutzerdefinierte Eigenschaften enthalten. Die Werte, die Entwickler diesen Eigenschaften während der Adaptererstellung zuweisen, können in der MobileFirst Operations Console auf der Registerkarte Konfigurationen für Ihren Adapter überschrieben werden, ohne dass der Adapter neu implementiert werden muss. Benutzredefinierte Eigenschaften können mit der Schnittstelle ConfigurationAPI gelesen und später zur Laufzeit weiter angepasst werden.

Hinweis: Die Elemente für die Konfigurationseigenschaften müssen sich unter dem Element JAXRSApplicationClass befinden.
Im obigen Beispiel wurden die Verbindungseinstellungen definiert und Standardwerte für die Einstellungen festgelegt, sodass sie später in der Klasse AdapterApplication verwendet werden können.

Das Element <property> wird mit folgenden Attributen verwendet:

  • name: Name der Eigenschaft, wie er in der Konfigurationsklasse definiert ist
  • defaultValue: Setzt den in der Konfigurationsklasse definierten Wert außer Kraft
  • displayName: Anzeigename, der in der Konsole erscheint (optional)
  • description: Beschreibung, die in der Konsole angezeigt wird (optional)
  • type: Stellt sicher, dass die Eigenschaft einen bestimmten Typ hat, z. B. integer, string oder boolean bzw. eine Liste mit gültigen Werten wie type="['1','2','3']" (optional)

Eigenschaften in der Konsole

Pull- und Push-Konfiguration

Angepasste Adaptereigenschaften können über die auf der Registerkarte Konfigurationsdateien angezeigte Adapterkonfiguraionsdatei gemeinsam genutzt werden.

Verwenden Sie dazu die nachfolgend beschriebenen Befehle pull und push in Maven oder in der MobileFirst CLI. Damit die Eigenschaften gemeinsam genutzt werden können, müssen Sie die Standardwerte der Eigenschaften ändern.

Führen Sie die Befehle im Stammordner des Maven-Adapterprojekts aus.

Maven

  • Konfigurationsdatei mit pull übertragen
    mvn adapter:configpull -DmfpfConfigFile=config.json
    
  • Konfigurationsdatei mit push übertragen
    mvn adapter:configpush -DmfpfConfigFile=config.json
    

MobileFirst CLI

  • Konfigurationsdatei mit pull übertragen
    mfpdev adapter pull
    
  • Konfigurationsdatei mit push übertragen
    mfpdev adapter push
    

Konfigurationen per Push-Operation auf mehrere Server übertragen

Die Befehle pull und push können helfen, diverse DevOps-Abläufe zu erstellen, die je nach Umgebung (DEV, QA, UAT, PRODUCTION) unterschiedliche Werte für Adapter erfordern.

Maven
Oben ist beschrieben, wie standardmäßig eine Datei config.json angegeben wird. Erstellen Sie Dateien mit unterschiedlichen Namen für verschiedene Ziele.

MobileFirst CLI
Verwenden Sie die Option –configFile oder -c, um eine von der Standarddatei abweichende Konfigurationsdatei anzugeben.

mfpdev adapter pull -c [adapterProject]/alternate_config.json

Weitere Informationen erhalten Sie, wenn Sie mfpdev help adapter pull/push eingeben.

Java-Ordner

Die Java-Quellen des Service JAX-RS 2.0 werden in diesen Ordner gestellt. Der Service JAX-RS 2.0 umfasst eine Anwendungsklasse (die com.ibm.mfp.adapter.api.MFPJAXRSApplication erweitert) und die Ressourcenklassen.

Die Anwendungs- und Ressourcenklassen von JAX-RS 2.0 definieren die Java-Methoden und ihre Zuordnung zu URLs.
Die Anwendungsklasse von JAX-RS 2.0 ist com.sample.JavaAdapterApplication und com.sample.JavaAdapterResource ist eine darin enthaltene JAX-RS-2.0-Ressource.

Anwendungsklasse von JAX-RS 2.0

Die Anwendungsklasse von JAX-RS 2.0 teilt dem JAX-RS-2.0-Framework mit, welche Ressourcen in der Anwendung enthalten sind.

package com.sample.adapter;

import java.util.logging.Logger;
import com.ibm.mfp.adapter.api.MFPJAXRSApplication;

public class JavaAdapterApplication extends MFPJAXRSApplication{

    static Logger logger = Logger.getLogger(JavaAdapterApplication.class.getName());

    @Override
    protected void init() throws Exception {
        logger.info("Adapter initialized!");
    }

    @Override
    protected String getPackageToScan() {
        // Das Paket mit dieser Klasse wird (rekursiv) gescannt, um JAX-RS-2.0-Ressourcen zu finden.
        return getClass().getPackage().getName();
    }
}

Die Klasse MFPJAXRSApplication scannt das Paket auf JAX-RS-2.0-Ressourcen und erstellt automatisch eine Liste. Außerdem ruft MobileFirst Server die Methode init der Klasse auf, sobald der Adapter implementiert ist, wenn die MobileFirst-Foundation-Laufzeit gestartet wird und vor der Bereitstellung von Services.

JAX-RS-2.0-Ressource

Die JAX-RS-2.0-Ressource ist ein POJO (Plain Old Java Object), das einer Stamm-URL zugeordnet ist und über Java-Methoden verfügt, um an diese Stamm-URL und die zugehörigen untergeordneten URLs gerichtete Anforderungen zu bedienen. Jede Ressource kann ein gesondertes URL-Set haben.

package com.sample.adapter;

import java.util.logging.Logger;

import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;

@Path("/")
public class JavaAdapterResource {

    // Logger definieren (Standard: java.util.Logger)
    static Logger logger = Logger.getLogger(JavaAdapterResource.class.getName());

    // Pfad für Methode: "<Serveradresse>/Adapters/adapters/JavaAdapter/{username}"
    @GET
    @Path("/{username}")
    public String helloUser(@PathParam("username") String name){
        return "Hello " + name;
    }
}
  • @Path("/") vor der Klassendefinition legt den Stammverzeichnispfad für diese Ressource fest. Wenn Sie mehrere Ressourcenklassen haben, sollten Sie für jede einen anderen Pfad definieren.

    Angenommen, Sie haben eine UserResource mit @Path("/users"), um die Benutzer eines Blogs zu verwalten. Diese Ressource wäre dann über http(s)://host:port/ProjectName/adapters/AdapterName/users/ zugänglich.

    Derselbe Adapter könnten eine weitere Ressource PostResource mit @Path("/posts") für die Verwaltung von Blogbeiträgen enthalten. Diese Ressource wäre dann über die URL http(s)://host:port/ProjectName/adapters/AdapterName/posts/ zugänglich.

    Da es im obigen Beispiel nur eine Ressourcenklasse gibt, ist diese auf @Path("/") gesetzt und damit über http(s)://host:port/Adapters/adapters/JavaAdapter/ zugänglich.

  • Jeder Methode wird mindestens eine JAX-RS-2.0-Annotation vorangestellt, z. B. eine Annotation für HTTP-Anforderungen wie @GET, @PUT, @POST, @DELETE oder @HEAD. Solche Annotationen definieren, wie auf die Methode zugegriffen werden kann.

  • Ein weiteres Beispiel ist @Path("/{username}"), das (neben dem Pfad auf Ressourcenebene) den Pfad für den Zugriff auf diese Prozedur definiert. Wie Sie sehen, kann dieser Pfad einen Variablenabschnitt enthalten. Diese Variable wird dann als Parameter der Methode verwendet (@PathParam("username") String name).

Sie können viele weitere Annoationen verwenden, die in der folgenden Zusammenfassung der Annotationstypen angegeben sind: https://jax-rs-spec.java.net/nonav/2.0-rev-a/apidocs/javax/ws/rs/package-summary.html

Wichtiger Hinweis: Wenn Sie in Ihrer Adapterimplementierung statische Referenzen auf Klassen von javax.ws.rs.* oder javax.servlet.* verwenden, müssen Sie RuntimeDelegate mit einer der folgenden Optionen konfigurieren:

  • Legen Sie in Liberty in der Datei jvm.options -Djavax.ws.rs.ext.RuntimeDelegate=org.apache.cxf.jaxrs.impl.RuntimeDelegateImpl fest. ODER
  • Legen Sie Sie die Systemeigenschaft oder angepasste JVM-Eigenschaft javax.ws.rs.ext.RuntimeDelegate=org.apache.cxf.jaxrs.impl.RuntimeDelegateImpl fest.

HTTP-Sitzung

MobileFirst Server ist nicht auf HTTP-Sitzungen angewiesen, und jede Anforderung kann von einem anderen Knoten empfangen werden. Sie sollten nicht darauf setzen, dass Daten von einer Anforderung zur nächsten durch HTTP-Sitzungen erhalten bleiben können.

Serverseitige APIs

Java-Adapter können serverseitige Java-APIs verwenden, um Operationen im Zusammenhang mit MobileFirst Server auszuführen: Aufrufen anderer Adapter, Anmeldung beim Serverprotokoll, Abrufen der Werte von Konfigurationseigenschaften, Melden von Aktivitäten an Analytics, Abrufen der Identität des Anforderungsausstellers.

Konfigurations-API

Die Klasse ConfigurationAPI stellt eine API bereit, mit der die in der Datei adapter.xml oder in der MobileFirst Operations Console definierten Eigenschaften abgerufen werden können.

Fügen Sie in Ihrer Java-Klasse Folgendes auf Klassenebene hinzu:

@Context
	ConfigurationAPI configurationAPI;

	```

Verwenden Sie dann die `configurationAPI`-Instanz zum Abrufen der Eigenschaften: 

```java
configurationAPI.getPropertyValue("DB_url");

Wenn die Adapterkonfiguration in der MobileFirst Operations Console modifiziert wird, wird die JAX-RS-Anwendungsklasse neu geladen und die Methode init dieser Klasse erneut aufgerufen.

Die Methode getServerJNDIProperty kann auch zum Abrufen einer JNDI-Eigenschaft aus Ihrer Serverkonfiguration verwendet werden.

Verwendungsbeispiele sind im Lernprogramm Java-SQL-Adapter enthalten.

Adapter-API

Die Klasse AdaptersAPI stellt eine API bereit, mit der Informationen zum aktuellen Adapter abgerufen und REST-Anforderungen an andere Adapter gesendet werden können.

Fügen Sie in Ihrer Java-Klasse Folgendes auf Klassenebene hinzu:

@Context
AdaptersAPI adaptersAPI;

Verwendungsbeispiele sind im Lernprogramm Erweiterte Nutzung von Adaptern und Adapterkombinationen enthalten.

Analytics-API

Die Klasse AnalyticsAPI stellt eine API bereit, mit der Informationen an Analytics gemeldet werden können.

Fügen Sie in Ihrer Java-Klasse Folgendes auf Klassenebene hinzu:

@Context
AnalyticsAPI analyticsAPI;

Verwendungsbeispiele sind im Lernprogramm Analytics-API enthalten.

Sicherheits-API

Die Klasse AdapterSecurityContext stellt den Adapter für einen REST-Adapteraufruf bereit.

Fügen Sie in Ihrer Java-Klasse Folgendes auf Klassenebene hinzu:

@Context
AdapterSecurityContext securityContext;

Anschließend können Sie beispielsweise wie folgt den aktuellen authentifizierten Benutzer (AuthenticatedUser) abrufen:

AuthenticatedUser currentUser = securityContext.getAuthenticatedUser();

Beispiele für Java-Adapter

Beispiele für Java-Adapter, die mit einem HTTP- oder SQL-Back-End kommunizieren, finden Sie unter:

Inclusive terminology note: The Mobile First Platform team is making changes to support the IBM® initiative to replace racially biased and other discriminatory language in our code and content with more inclusive language. While IBM values the use of inclusive language, terms that are outside of IBM's direct influence are sometimes required for the sake of maintaining user understanding. As other industry leaders join IBM in embracing the use of inclusive language, IBM will continue to update the documentation to reflect those changes.
Last modified on February 27, 2020