Java-Programme durch PlugIns erweitern

Aus Byte-Welt Wiki
Version vom 17. Oktober 2008, 08:34 Uhr von EagleEye (Diskussion | Beiträge) (Die Seite wurde neu angelegt: Damit Programme leicht um neue Teile erweitert werden können, ist es hilfreich diese mit einer Plugin-Schnittstelle auszustatten. ==Voraussetzungen== Als ...)
(Unterschied) ← Nächstältere Version | Aktuelle Version (Unterschied) | Nächstjüngere Version → (Unterschied)
Zur Navigation springenZur Suche springen

Damit Programme leicht um neue Teile erweitert werden können, ist es hilfreich diese mit einer Plugin-Schnittstelle auszustatten.

Voraussetzungen

Als Voraussetzung für die Verwendung von Plugins sollten verschiedene Klassen und Interfaces vorhanden sein:

  1. Plugin-Interface - das die Plugins implementieren müssen. Hiermit wird festgelegt welche Funktionen das Plugin der Anwendung anbieten muss.
  2. Anwendung-Interface - das die Schnittstelle von den Plugins zur Anwendung darstellt, hiermit kann kontrolliert werden was die Anwendungen dürfen und was sie sehen.
  3. Manager - gesonderte Klasse für das Laden, Starten und Beenden der Plugins.

Die Interfaces

Das gesamte Plugin-System könnte auch ohne Interfaces geschrieben werden, jedoch ist dies unsicherer. Weil wenn dafür die Klassen der Anwendung eingebunden werden müssen und mit Entwicklungsumgebungen wie Eclipse kann der Programmierer alle Methoden sehen und auf diese zugreifen. Die Interfaces schließen dies nicht aus aber bilden eine saubere Trennung.

Das Plugin-Interface

Das Interface für die Plugins kann keine Methoden umfassen, aber auch viele verschiedene. Es sollte nach meiner derzeitigen Auffassung jedoch immer zwei Methoden besitzen start und stop. Außerdem eine Methode um die Manager-Klasse zu setzen, sollte das Plugin auf irgendwelche Eigenschaften der Anwendung zugreifen können. <code=java> public interface PluginInterface{

 public boolean start();
 public boolean stop();
 public void setPluginManager(PluginManager manager);
 public void hello();

} </code=java> Zusätzlich wurde das Interface um die Methode hello erweitert, somit kann das Plugin von der Anwendung auch benachrichtigt werden.

Das PluginManager-Interface

Das Interface für den Pluginmanager bildet die Schnittstelle vom Plugin zur Anwendung, hier werden alle Methoden aufgeführt die das Plugin aufrufen darf. <code=java> public interface PluginManager{

 public void openWindow(String msg);

} </code=java> Unser PLuginmanager erlaubt nur das Öffnen eines Fensters mit einem String als Nachricht.


Implementierungen

Durch die Interfaces muss für die Entwicklung des Plugins nur die Class- oder Java-Dateien weiter gegeben werden, die Implementierungen des PluginManagers dagegen nicht.

Hello-Plugin

Unser Plugin soll beim Aufruf der hello()-Methode nur ein Fenster öffnen und dort Hallo ausgeben, daher fällt die Implementierung sehr einfach aus. Die start()- und stop()-Methoden werden garnicht benötigt, würde der Text aus einer Datenbank oder Datei gelesen werden könnte dies in der start-Methode erledigt werden <code=java> public class HelloPlugin implements PluginInterface{

 private PluginManager manager;
 public boolean start(){
   System.out.println("ich starte");
   return true;
 }
 public boolean stop(){
   System.out.println("ich stoppe");
   return true;
 }
 public void setPluginManager(PluginManager manager){
   this.manager = manager;
 }
 public void hello(){
   manager.openWindow("hallo");
 }

</code=java>