Sling Servlet

Ein Servlet ist eine Klasse, die verwendet wird, um die Funktionen von Servern zu erweitern, die Anwendungen hosten, auf die über ein Programmiermodell für Anforderungsantworten zugegriffen wird. Für solche Anwendungen definiert die Servlet-Technologie HTTP-spezifische Servlet-Klassen.
Alle Servlets müssen die Servlet-Schnittstelle implementieren, die Lebenszyklusmethoden definiert.

Ein Servlet in AEM kann als OSGi-Dienst registriert werden: Sie können SlingSafeMethodsServlet für schreibgeschützte Implementierung oder SlingAllMethodsServlet erweitern, um alle RESTful-Vorgänge zu implementieren.

Servlet-Code

package com.mysite.core.servlets;
import javax.servlet.Servlet;
import org.apache.sling.api.SlingHttpServletRequest;
import org.apache.sling.api.SlingHttpServletResponse;
import org.apache.sling.api.servlets.SlingAllMethodsServlet;
import org.osgi.service.component.annotations.Component;
import org.osgi.service.component.annotations.Reference;

import com.adobe.aemfd.docmanager.Document;
import com.adobe.fd.forms.api.FormsService;

@Component(service={Servlet.class}, property={"sling.servlet.methods=post", "sling.servlet.paths=/bin/mergedataWithAcroform"})
public class MyFirstAEMFormsServlet extends SlingAllMethodsServlet
{

    private static final long serialVersionUID = 1L;
    @Reference
    FormsService formsService;
     protected void doPost(SlingHttpServletRequest request, SlingHttpServletResponse response)
      {
         String file_path = request.getParameter("save_location");

         java.io.InputStream pdf_document_is = null;
         java.io.InputStream xml_is = null;
         javax.servlet.http.Part pdf_document_part = null;
         javax.servlet.http.Part xml_data_part = null;
              try
              {
                 pdf_document_part = request.getPart("pdf_file");
                 xml_data_part = request.getPart("xml_data_file");
                 pdf_document_is = pdf_document_part.getInputStream();
                 xml_is = xml_data_part.getInputStream();
                 Document data_merged_document = formsService.importData(new Document(pdf_document_is), new Document(xml_is));
                 data_merged_document.copyToFile(new File(file_path));

              }
              catch(Exception e)
              {
                  response.sendError(400,e.getMessage());
              }
      }
}

Erstellen und Bereitstellen

Gehen Sie wie folgt vor, um Ihr Projekt zu erstellen:

  • Öffnen Eingabeaufforderungsfenster
  • Navigieren Sie zu c:\aemformsbundles\mysite\core
  • Ausführen des Befehls mvn clean install -PautoInstallBundle
  • Der obige Befehl erstellt das Bundle automatisch und stellt es in Ihrer AEM-Instanz bereit, die auf localhost:4502 ausgeführt wird.

Das Bundle ist auch am folgenden Speicherort verfügbar: C:\AEMFormsBundles\mysite\core\target. Das Bundle kann auch in AEM mit der Felix Web-Konsole.

Servlet-Resolver testen

Verweisen Sie den Browser auf Servlet-Resolver-URL. Dies teilt Ihnen das Servlet mit, das für einen bestimmten Pfad aufgerufen wird, wie im Screenshot unten dargestellt
servlet-resolver

Testen des Servlets mit Postman

Testen des Servlets mit Postman

Auf dieser Seite