AEM vous permet d’exporter une page sous la forme d’une page web complète comprenant des images, des fichiers .js
et .css
.
Une fois la configuration effectuée, vous demandez l’exportation d’une page à partir de votre navigateur en remplaçant html
par export.zip
dans l’URL. Cette opération génère un fichier d’archive (zip) contenant la page rendue au format html, ainsi que les ressources référencées. Tous les chemins d’accès de la page (par exemple, les chemins d’accès aux images) sont réécrits afin de pointer vers les fichiers inclus dans l’archive ou vers les ressources du serveur. Le fichier d’archive (zip) peut ensuite être téléchargé à partir de votre navigateur.
Selon votre navigateur et les paramètres, le téléchargement sera :
<page-name>.export.zip
) ;<page-name>
); en fait, le fichier d’archive a déjà été développé.La procédure ci-dessous décrit comment exporter une page et considère qu’il existe un modèle de de l’exportation pour votre site. Un modèle d’exportation définit la manière dont une page est exportée et est spécifique à votre site. Pour créer un modèle d’exportation, reportez-vous à la section Création d’une configuration d’exportateur de page pour votre site .
Pour exporter une page, procédez comme suit :
Accédez à la page requise dans la console Sites.
Sélectionnez la page, puis ouvrez la boîte de dialogue Propriétés.
Sélectionnez l’onglet Avancé.
Développez le champ Export pour sélectionner un modèle d'export.
Sélectionnez le modèle requis pour votre site, puis confirmez avec OK.
Sélectionnez Enregistrer et fermer pour fermer la boîte de dialogue des propriétés de la page.
Demandez la page à exporter, en remplaçant le suffixe html
par export.zip
dans l’URL.
Par exemple :
Est accessible via :
Téléchargez le fichier d’archive sur votre système de fichiers.
Dans votre système de fichiers, décompressez le fichier si nécessaire. Une fois développé, un dossier portant le même nom que la page sélectionnée s’affiche. Ce dossier contient :
le sous-dossier content
, qui est la racine d’une série de sous-dossiers qui reflètent le chemin d’accès à la page dans le référentiel.
<page-name>.html
).autres ressources (.js
fichiers, .css
fichiers, images, etc.) se situent en fonction des paramètres du modèle d’exportation.
Ouvrez le fichier HTML de la page (<unzip-dir>/<path>/<to>/<page>/<page-path>.html
) dans votre navigateur pour vérifier le rendu.
L’exportateur de page est basé sur la structure de synchronisation de contenu. Les configurations disponibles dans la boîte de dialogue Propriétés de page sont des modèles d’exportation qui définissent les dépendances requises pour une page.
Lorsqu’une exportation de page est déclenchée, le modèle d’exportation est référencé et le chemin de page et le chemin de conception sont appliqués dynamiquement. Le fichier compressé est alors créé à l’aide de la fonctionnalité de synchronisation de contenu standard.
Une installation AEM prête à l’emploi comprend un modèle par défaut sous /etc/contentsync/templates/default
.
Ce modèle est le modèle de secours lorsqu’aucun modèle d’exportation n’est trouvé dans le référentiel.
Le modèle default
indique comment une exportation de page peut être configurée, afin de servir de base à un nouveau modèle d’exportation.
Pour afficher la structure de noeud du modèle dans votre navigateur au format JSON, demandez l’URL suivante :
http://localhost:4502/etc/contentsync/templates/default.json
La méthode la plus simple pour créer un modèle d’exportateur de page consiste à :
copier le modèle default
,
attribuer un nouveau nom, approprié à votre site,
effectuez ensuite les mises à jour requises.
Pour créer un modèle totalement nouveau :
Dans CRXDE Lite, créez un noeud sous /etc/contentsync/templates
:
Name
: un nom approprié à votre site ; par exemple, <mysite>
. Le nom apparaît dans la boîte de dialogue Propriétés de la page lors du choix du modèle d’exportateur de page.
Type
: nt:unstructured
Sous le noeud de modèle, appelé ici mysite
, créez une structure de noeud à l’aide des noeuds de configuration décrits ci-dessous.
Une fois votre modèle paramétré, vous devez le rendre disponible :
Dans CRXDE, accédez à la page requise dans la branche /content
. Il peut s’agir d’une page individuelle ou de la page racine d’une sous-arborescence.
Sur le noeud jcr:content
de la page, créez la propriété :
Name
: cq:exportTemplate
Type
: String
Value
: chemin d’accès au modèle ; par exemple : /etc/contentsync/templates/mysite
Le modèle se compose d’une structure de noeud, car il utilise la structure de synchronisation de contenu. Chaque nœud possède une propriété type
qui définit une action spécifique dans le processus de création du fichier compressé.
Les nœuds ci-dessous peuvent être utilisés pour créer un modèle de d’exportation :
page
Le nœud page est utilisé pour copier le code HTML de la page dans le fichier compressé. Il possède les caractéristiques suivantes :
/etc/contentsync/templates/<mysite>
.Name
définie sur page
.nt:unstructured
Le nœud page
possède les propriétés suivantes :
Une propriété type
définie avec la valeur pages
.
Il ne comporte pas de propriété path
, car le chemin d’accès actuel à la page est copié dynamiquement dans la configuration.
rewrite
Le nœud rewrite définit la façon dont les liens sont réécrits dans la page exportée. Les liens réécrits peuvent pointer vers les fichiers inclus dans le fichier compressé ou vers les ressources sur le serveur.
design
Le nœud design est utilisé pour copier la conception utilisée pour la page exportée. Il possède les caractéristiques suivantes :
/etc/contentsync/templates/<mysite>
.Name
définie sur design
.nt:unstructured
.Le nœud design
possède les propriétés suivantes :
Une propriété type
définie sur la valeur copy
.
Il ne possède pas de propriété path
, car le chemin de page actuel est copié dynamiquement dans la configuration.
generic
Un noeud générique est utilisé pour copier des ressources telles que clientlibs.
.js
ou .css
au fichier zip. Il possède les caractéristiques suivantes :
/etc/contentsync/templates/<mysite>
.nt:unstructured
.type
et des propriétés type
associées. Par exemple, le noeud de configuration suivant copie les fichiers mysite.clientlibs.js
dans le fichier zip :
"mysite.clientlibs.js": {
"extension": "js",
"type": "clientlib",
"path": "/etc/designs/mysite/clientlibs",
"jcr:primaryType": "nt:unstructured"
}
Mise en œuvre d’une configuration personnalisée
Des configurations personnalisées sont également possibles.
Pour répondre à certaines exigences spécifiques, vous devrez peut-être implémenter un gestionnaire de mise à jour personnalisé.
Pour exporter une page par programmation, vous pouvez utiliser le service OSGi PageExporter. Ce service permet ce qui suit :
Le servlet lié au sélecteur export
et à l’extension zip
utilise le service PageExporter.
Si vous rencontrez un problème lors du téléchargement du fichier zip, vous pouvez supprimer le noeud /var/contentsync
dans le référentiel et envoyer à nouveau la demande d’exportation.