Sling Servlet
Um Servlet é uma classe usada para estender os recursos dos servidores que hospedam aplicativos acessados por meio de um modelo de programação de solicitação-resposta. Para tais aplicações, a tecnologia Servlet define classes de servlet específicas de HTTP.
Todos os servlets devem implementar a interface Servlet, que define os métodos do ciclo de vida.
Um servlet no AEM pode ser registrado como um serviço OSGi: é possível estender SlingSafeMethodsServlet para implementação somente leitura ou SlingAllMethodsServlet para implementar todas as operações RESTful.
Código de servlet
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 java.io.File;
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());
}
}
}
Criar e implantar
Para criar seu projeto, siga as seguintes etapas:
- Abrir janela do prompt de comando
- Navegue até
c:\aemformsbundles\mysite\core
- Executar o comando
mvn clean install -PautoInstallBundle
- O comando acima cria e implanta automaticamente o pacote na instância do AEM em execução em localhost:4502
O pacote também está disponível no seguinte local C:\AEMFormsBundles\mysite\core\target
. O pacote também pode ser implantado no AEM usando o Felix web console.
Testar o resolvedor de servlet
Aponte seu navegador para o URL do resolvedor de servlet. Isso informa o servlet que é chamado para um determinado caminho, conforme visto na captura de tela abaixo
Testar o servlet usando o Postman