Flujos de trabajo de relleno automático recomendados y envío basados en fuentes de datos para formularios adaptables recommended-data-source-btased-prefill-and-submit-workflows-for-adaptive-forms

Puede utilizar cualquiera de las siguientes fuentes de datos con formularios adaptables convertidos mediante el servicio de conversión automatizada de formularios:

  • Modelo de datos de formulario, OData o cualquier otro servicio de terceros
  • Esquema JSON
  • Esquema XSD

En función de la fuente de datos, puede optar por generar un formulario adaptable con o sin un modelo de datos.

En este artículo se describen los flujos de trabajo recomendados para rellenar automáticamente los valores de campo y las opciones de envío después de seleccionar una fuente de datos y generar un formulario adaptable mediante el servicio de conversión.

Fuente de datos
Flujo de trabajo recomendado
Modelo de datos de formulario, OData o cualquier otro servicio de terceros
Opción 1: se selecciona el modelo de datos de formulario, OData o cualquier otro servicio de terceros como fuente de datos. Puede generar un formulario adaptable sin enlace de datos mediante el servicio de conversión automática de formularios. Los campos de formulario adaptables se vinculan manualmente a las entidades del modelo de datos de formulario y se utiliza la opción Servicio de relleno automático del modelo de datos de formulario para rellenar automáticamente los valores de los campos. Para enviar el formulario adaptable se utiliza la opción Enviar con el modelo de datos de formulario.
Opción 2: seleccione el modelo de datos de formulario, OData o cualquier otro servicio de terceros como fuente de datos. Puede generar un formulario adaptable sin enlace de datos mediante el uso del servicio de conversión automática de formularios. Los campos de formulario adaptables se enlazan con el editor de reglas para rellenar automáticamente los valores de campo. Modifique los valores de los campos, si es necesario, y envíe datos al repositorio de crx.
Para obtener instrucciones paso a paso sobre la ejecución de estos flujos de trabajo, consulte Utilice la base de datos, OData o cualquier servicio de terceros como fuente de datos.
Esquema JSON
El esquema JSON se selecciona como fuente de datos. En función de la fuente de datos seleccionada:
Opción 1: para generar un formulario adaptable sin enlace de datos mediante el uso del servicio de conversión automática de formularios y la configuración del esquema JSON como fuente de datos. Los campos de formulario adaptables se enlazan manualmente al esquema JSON y usar cualquiera de los protocolos admitidos para rellenar automáticamente los valores de campo. Modifique los valores de los campos, si es necesario, y envíe datos al repositorio de crx.
Para obtener instrucciones paso a paso para ejecutar los flujos de trabajo, consulte Utilización del esquema JSON como fuente de datos.
Opción 2: puede generar un formulario adaptable con enlace de datos JSON mediante el uso del servicio de conversión automática de formularios. El servicio de relleno automático y el envío de formularios funcionan sin problemas. No necesita ningún paso de configuración.
Para obtener instrucciones paso a paso para ejecutar los flujos de trabajo, consulte Utilización del esquema JSON como fuente de datos.
Esquema XSD
El esquema XSD se selecciona como fuente de datos. En función de la fuente de datos seleccionada, puede generar un formulario adaptable sin enlace de datos mediante el uso del servicio de conversión automatizada de formularios y la configuración del esquema XSD como fuente de datos. Los campos de formulario adaptables se enlazan manualmente al esquema XSD y usar cualquiera de los protocolos admitidos para rellenar automáticamente los valores de campo. Modifique los valores de los campos, si es necesario, y envíe datos al repositorio de crx.
Para obtener instrucciones paso a paso para ejecutar los flujos de trabajo, consulte Utilización del esquema XSD como fuente de datos.

Para obtener más información sobre el servicio de conversión automatizada de formulario, consulte los siguientes artículos:

La información proporcionada en este artículo se basa en la suposición de que cualquiera que la lea tiene conocimientos básicos sobre los conceptos de formularios adaptables.

Requisitos previos pre-requisites

Formulario adaptable de ejemplo sample-adaptive-form

Para ejecutar los casos de uso con el fin de rellenar automáticamente los valores de campo en un formulario adaptable y enviarlos a la fuente de datos, descargue el siguiente archivo PDF de ejemplo.

Formulario de solicitud de préstamo de ejemplo

Obtener archivo

El archivo PDF sirve como entrada al servicio de conversión automatizada de formularios. El servicio convierte este archivo en un formulario adaptable. La siguiente imagen muestra la aplicación de un préstamo de ejemplo en formato PDF.

formulario de solicitud de préstamo de ejemplo

Preparación de datos para el modelo de formulario prepare-data-for-form-model

La integración de datos de AEM Forms le permite configurar y conectarse a fuentes de datos diferentes. Después de generar un formulario adaptable mediante el proceso de conversión, puede definir el modelo de formulario basado en un modelo de datos de formulario, XSD o un esquema JSON. Puede utilizar una base de datos, Microsoft Dynamics o cualquier otro servicio de terceros para crear un modelo de datos de formulario.

Este tutorial utiliza la base de datos MySQL como fuente para crear un modelo de datos de formulario. Cree un esquema de aplicación de préstamo en la base de datos y añada un solicitante al esquema en función de los campos disponibles en el formulario adaptable.

Datos de muestra MySQL

Puede utilizar la siguiente sentencia DDL para crear la tabla solicitante en la base de datos.

CREATE TABLE `applicant` (
   `name` varchar(45) DEFAULT NULL,
   `address` varchar(45) DEFAULT NULL,
   `phonenumber` int(11) NOT NULL,
   `email` varchar(45) DEFAULT NULL,
   `occupation` varchar(45) DEFAULT NULL,
   `annualsalary` varchar(45) DEFAULT NULL,
   `familymembers` int(11) DEFAULT NULL,
   PRIMARY KEY (`phonenumber`)
 ) ENGINE=InnoDB DEFAULT CHARSET=utf8

Si utiliza un esquema XSD como modelo de formulario para ejecutar los casos de uso, cree un archivo XSD con el siguiente texto:

<?xml version="1.0" encoding="utf-8" ?>
    <xs:schema targetNamespace="http://adobe.com/sample.xsd"
                    xmlns="http://adobe.com/sample.xsd"
                    xmlns:xs="http://www.w3.org/2001/XMLSchema">

<xs:element name="sample" type="SampleType"/>

  <xs:complexType name="SampleType">
    <xs:sequence>
      <xs:element name="name" type="xs:string"/>
   <xs:element name="address" type="xs:string"/>
   <xs:element name="phonenumber" type="xs:int"/>
   <xs:element name="email" type="xs:string"/>
   <xs:element name="occupation" type="xs:string"/>
   <xs:element name="annualsalary" type="xs:string"/>
   <xs:element name="familymembers" type="xs:string"/>
 </xs:sequence>
  </xs:complexType>

  </xs:schema>

O descargue el esquema XSD en el sistema de archivos local.

Esquema XSD de aplicación de préstamo de muestra

Obtener archivo

Para obtener más información sobre el uso del esquema XSD como modelo de formulario en formularios adaptables, consulte Creación de formularios adaptables con esquema XML.

Si utiliza un esquema JSON como modelo de formulario para ejecutar los casos de uso, cree un archivo JSON con el siguiente texto:

{
    "$schema": "http://json-schema.org/draft-04/schema#",
    "definitions": {
        "loanapplication": {
            "type": "object",
            "properties": {
                "name": {
                    "type": "string"
                },
                "address": {
                    "type": "string"
                },
    "phonenumber": {
                    "type": "number"
                },
    "email": {
                    "type": "string"
                },
    "occupation": {
                    "type": "string"
                },
    "annualsalary": {
                    "type": "string"
                },
    "familymembers": {
                    "type": "number"
                }
            }
        }
 },
 "type": "object",
    "properties": {
        "employee": {
            "$ref": "#/definitions/loanapplication"
        }
    }
}

O descargue el esquema JSON en el sistema de archivos local.

Esquema JSON de aplicación de préstamo de muestra

Obtener archivo

Para obtener más información sobre el uso del esquema JSON como modelo de formulario en formularios adaptables, consulte Creación de formularios adaptables mediante el esquema JSON.

Generar formularios adaptables sin enlace de datos generate-adaptive-forms-with-no-data-binding

Utilice el servicio de conversión automatizada de formularios para convertir el formulario de solicitud de préstamo de ejemplo a un formulario adaptable sin enlace de datos. Asegúrese de seleccionar la casilla Generate adaptive form(s) without data bindings para generar el formulario adaptable sin enlace de datos.

Formulario adaptable sin enlace de datos

Después de generar un formulario adaptable sin enlace de datos, seleccione una fuente de datos para el formulario adaptable:

NOTE
Si el formulario adaptable que convierte mediante el servicio de conversión automatizada de formularios contiene varios campos con el mismo nombre, asegúrese de que dichos campos estén enlazados a entidades de la fuente de datos para evitar una posible pérdida de datos durante el envío.

Utilizar base de datos, OData o cualquier servicio de terceros como fuente de datos sqldatasource

Caso de uso: puede generar un formulario adaptable sin enlace de datos utilizando el servicio de conversión automatizada de formularios y configurar la base de datos MySQL como fuente de datos. Los campos de formulario adaptables se enlazan manualmente a las entidades del modelo de datos de formulario y se usa la opción Form Data Model Prefill Service para rellenar automáticamente los valores de campo. Utilice la opción Submit using Form Data Model para enviar el formulario adaptable.

Antes de ejecutar el caso de uso:

En función del caso de uso, cree el modelo de datos de formulario aplicación de préstamo y enlace el argumento de servicio de lectura al valor Literal. El valor literal del número de teléfono debe ser de uno de los registros configurados en el esquema solicitante de la base de datos MySQL. Los servicios utilizan el valor como argumento para recuperar detalles de la fuente de datos. También puede seleccionar el Atributo de perfil de usuario o atributo de solicitud de la lista desplegable Binding To.

Configurar un modelo de datos de formulario

NOTE
Asegúrese de agregar los servicios get y insert al modelo de datos de formulario, configurar y probar los servicios antes de ejecutar el caso de uso.

Siga estos pasos:

  1. Seleccione el formulario de solicitud de préstamo de ejemplo convertido disponible en la carpeta output y toque Properties.

  2. Desde la pestaña Form Model, seleccione Form Data Model desde la lista desplegable Select From y pulse Select Form Data Model para seleccionar el modelo de datos del formulario aplicación de préstamo. Toque Save & Close para guardar el formulario.

  3. Seleccione el formulario de solicitud de préstamo de ejemplo y toque Edit.

  4. En la pestaña Content, pulse el icono configurar:

    configurar el contenedor de formulario

    1. En la sección Basic, elija Form Data Model Prefill service desde la lista desplegable Prefill Service.

    2. En la sección Submission, seleccione Submit using Form Data Model desde la Submit Action lista desplegable.

    3. Seleccione el modelo de datos con el campo Data Model to submit.

    4. Pulse done_icon para guardar las propiedades.

  5. Pulse el cuadro de texto Nombre del solicitante y seleccione icono de configuración (Configurar).

    1. En el campo Referencia de enlace, seleccione Solicitante > Nombre y presione icono Listo para guardar las propiedades. Del mismo modo, cree un enlace de datos para los campos Dirección, Número de teléfono, Correo electrónico, Ocupación, Salario anual (en dólares) y cantidad de familiares dependientes con las entidades del modelo de datos de formulario.

    Enlazar referencias

  6. Toque Preview para ver los valores de campo de formulario adaptable rellenados previamente de forma automática.

  7. Modifique los valores de los campos si es necesario y envíe el formulario adaptable. Los valores de campo se envían a la base de datos MySQL. Puede actualizar la tabla solicitante para ver los valores actualizados de la tabla.

Caso de uso: puede generar un formulario adaptable sin enlace de datos utilizando el Servicio de conversión automatizada de formularios y configurar la base de datos MySQL como la fuente de datos. Los campos de formulario adaptables se enlazan con el editor de reglas para rellenar automáticamente los valores de campo. Modifique los valores de los campos, si es necesario, y envíe datos al repositorio de crx.

Siga estos pasos para utilizar el editor de reglas para invocar el servicio del modelo de datos de formulario para enlazar campos y rellenar automáticamente los valores en un formulario adaptable.

  1. Seleccione el formulario de solicitud de préstamo de ejemplo en la carpeta output y toque Edit.

  2. En la pestaña Content, pulse el icono configurar:

    configurar el contenedor de formulario

    En la sección Basic, elija Form Data Model Prefill service desde la lista desplegable Prefill Service.

  3. Toque el cuadro de texto Applicant Name y elija Edit Rules.

    Editar reglas para crear enlaces de datos

  4. Seleccione Create en la página Editor de reglas.

  5. En la página Rule Editor:

    1. Seleccione un estado para el cuadro de texto Nombre del solicitante. Por ejemplo, is initialized, lo que resulta en la ejecución de la condición Then cuando se procesa el formulario en el modo Preview.

    2. En la sección Then, elija Invoke Service de la lista desplegable Select Action. Todos los servicios de la instancia de formularios se muestran en la lista desplegable.

    3. Seleccione un servicio Get desde la sección que enumera los modelos de datos de formulario. Se muestra el campo Entrada númerodeteléfono, que es la clave principal definida para el modelo de datos solicitante. El sistema recupera y rellena automáticamente los valores del formulario adaptable de los campos de la sección Salida basándose en este campo.

    4. Cree un enlace para los campos de formulario adaptables con las entidades del modelo de datos de formulario utilizando la sección Salida. Por ejemplo, enlace el campo del formulario adaptable Applicant Name con la entidad nombre.

    5. Toque Done. Toque Done de nuevo en la página Editor de reglas.

    Editor de reglas para enlazar referencias

  6. Toque Preview para ver los valores de campo de formulario adaptable rellenados de forma automática previamente.

    note note
    NOTE
    Asegúrese de que la propiedad Return Array se desactive para la propiedad del servicio GET en el modelo de datos de formulario asociado al formulario adaptable.
  7. Modifique los valores de los campos si es necesario y envíe el formulario adaptable. Los datos enviados están disponibles en la siguiente ubicación del repositorio crx:

    http://host name:port/crx/de/index.jsp#/content/forms/fp/admin/submit/data/latest file available in the folder

Usar el esquema JSON como fuente de datos jsondatasource

Caso de uso: puede generar un formulario adaptable sin enlace de datos mediante el servicio de conversión automatizada de formularios y configurar el esquema JSON como fuente de datos. Los campos del formulario adaptable se enlazan manualmente al esquema JSON y se utiliza la opción Vista previa con los datos para rellenar automáticamente los valores del campo. Modifique los valores de los campos, si es necesario, y envíe datos al repositorio de crx.

Antes de ejecutar el caso de uso, asegúrese de lo siguiente:

Siga estos pasos:

  1. Seleccione el formulario de solicitud de préstamo de ejemplo convertido disponible en la carpeta de Salida y toque Properties.

  2. Toque la pestaña Form Model, seleccione Schema de la lista desplegable Select From y pulse Select Schema para cargar el esquema JSON de demo.schema guardado en el sistema de archivos local. Toque Save & Close para guardar el formulario.

  3. Seleccione el formulario de solicitud de préstamo de ejemplo y toque Edit.

  4. Pulse el cuadro de texto Nombre del solicitante y seleccione icono de configuración (Configurar).

    En el campo Referencia de enlace, seleccione Solicitante > Nombre y presione icono Listo para guardar las propiedades. Del mismo modo, cree un enlace de datos para los campos Dirección, Número de teléfono, Correo electrónico, Ocupación, Salario anual (en dólares) y cantidad de familiares dependientes con las entidades del esquema JSON.

  5. Seleccione nuevamente el formulario de solicitud de préstamo de ejemplo convertido disponible en la carpeta output y presione Preview > Preview with Data.

    Descargar archivo de datos de ejemplo

    Obtener archivo

  6. Modifique los valores de los campos si es necesario y envíe el formulario adaptable. Los datos enviados están disponibles en la siguiente ubicación del repositorio crx:

    http://host name:port/crx/de/index.jsp#/content/forms/fp/admin/submit/data/latest file available in the folder

Utilizar el esquema XSD como fuente de datos xsddatasource

Caso de uso: puede generar un formulario adaptable sin enlace de datos utilizando el servicio de conversión automatizada de formularios y configurar el esquema XSD como fuente de datos. Los campos de formulario adaptables se enlazan manualmente al esquema XSD y se utiliza la variable Vista previa con datos para rellenar automáticamente los valores de campo. Modifique los valores de los campos, si es necesario, y envíe datos al repositorio de crx.

Antes de ejecutar el caso de uso, asegúrese de lo siguiente:

Siga estos pasos:

  1. Seleccione el formulario de solicitud de préstamo de ejemplo convertido disponible en la carpeta output y toque Properties.

  2. Toque la pestaña Form Model, seleccione Schema de la lista desplegable Select From y pulse Select Schema para cargar el esquema XSD aplicación de préstamo guardado en el sistema de archivos local. Seleccione el elemento raíz para el esquema XSD y pulse Save & Close para guardar el formulario.

  3. Seleccione el formulario de solicitud de préstamo de ejemplo y toque Edit.

  4. Pulse el cuadro de texto Nombre del solicitante y seleccione icono de configuración (Configurar).
    En el campo Referencia de enlace, seleccione Solicitante > Nombre y presione icono Listo para guardar las propiedades. Del mismo modo, cree un enlace de datos para los campos Dirección, Número de teléfono, Correo electrónico, Ocupación, Salario anual (en dólares) y cantidad de familiares dependientes con las entidades de esquema XSD.

  5. Seleccione nuevamente el formulario de solicitud de préstamo de ejemplo convertido disponible en la carpeta salida y presione Preview > Preview with Data.

    Descargar archivo de datos de ejemplo

    Obtener archivo

  6. Modifique los valores de los campos si es necesario y envíe el formulario adaptable. Los datos enviados están disponibles en la siguiente ubicación del repositorio crx:

    http://host name:port/crx/de/index.jsp#/content/forms/fp/admin/submit/data/latest file available in the folder

Generación de formularios adaptables con enlace JSON generate-adaptive-forms-with-json-binding

Utilice el servicio de conversión automatizada de formularios para convertir el formulario de solicitud de préstamo de ejemplo a un formulario adaptable con enlace de datos. Asegúrese de no seleccionar la casilla Generate adaptive form(s) without data bindings para generar el formulario adaptable.

Formulario adaptable con enlace JSON

Usar el esquema JSON como fuente de datos jsonwithdatabinding

Caso de uso: puede generar un formulario adaptable con enlace de datos JSON mediante el servicio de conversión automatizada de formularios. El servicio de relleno automático y el envío de formularios funcionan sin problemas. No necesita ningún paso de configuración.

Antes de ejecutar el caso de uso, asegúrese de que tiene un formulario adaptable con enlace de datos.

Siga estos pasos:

  1. Seleccione el formulario de solicitud de préstamo de ejemplo convertido disponible en la carpeta output de nuevo y presione Preview > Preview with Data.

    Descargar archivo de datos de ejemplo

    Obtener archivo

  2. Modifique los valores de los campos si es necesario y envíe el formulario adaptable. Los datos enviados están disponibles en la siguiente ubicación del repositorio crx:

    http://host name:port/crx/de/index.jsp#/content/forms/fp/admin/submit/data/latest file available in the folder

Conversión de datos JSON del formulario adaptable enviado al formato XML convert-submitted-adaptive-form-data-to-xml

Cuando se introducen valores en campos de formulario adaptables y se envían, los datos están disponibles en formato JSON en el repositorio crx. Puede convertir el formato de los datos JSON a XML con la API org.apache.sling.commons.json.xml o con el siguiente código de ejemplo:

import org.apache.sling.commons.json.JSONException;
import org.apache.sling.commons.json.JSONObject;
import org.apache.sling.commons.json.xml.XML;

public class ConversionUtils {

    public static String jsonToXML(String jsonString) throws JSONException {
        //https://sling.apache.org/apidocs/sling5/org/apache/sling/commons/json/xml/XML.html#toString(java.lang.Object)
        //jar - http://maven.ibiblio.org/maven2/org/apache/sling/org.apache.sling.commons.json/2.0.18/
        //Note: Need to extract boundData part before converting to XML
        return XML.toString(new JSONObject(jsonString));
    }
}
recommendation-more-help
c40c2ccf-3d1b-4b47-b158-c4646051b46c