XXXVI. Forms Data Format

Introduction

Forms Data Format (FDF) est un format de formulaire pour les documents PDF. Vous pouvez lire la documentation (en anglais) à http://partners.adobe.com/asn/acrobat/forms.jsp pour plus de détails sur les tenants et les aboutissants.

L'esprit de FDF est similaire à celui des formulaires HTML. Les différences résident dans les moyens de transmission des données au serveur, lorsque le bouton "submit" (soumettre) est pressé (ce qui est du ressort de Form Data Format) et le format de formulaire lui-même (qui est plutôt du ressort de Portable Document Format, PDF). Gérer des données FDF est un des objectifs des fonctions FDF. Mais il y en a d'autres. Vous pouvez aussi prendre un formulaire PDF, et pré-remplir les champs, sans modifier le formulaire lui-même. Dans ce cas, on va créer un document FDF (fdf_create()), remplir les champs (fdf_set_value()) et l'associer à un fichier PDF (fdf_set_file()). Finalement, le tout sera envoyé au client, avec le type MIME application/vnd.fdf. Le module "Acrobat reader" de votre navigateur va reconnaître ce type MIME, et lire le fichier PDF, puis le remplir avec FDF.

Si vous éditez un fichier FDF avec un éditeur de texte, vous trouverez un catalogue d'objet avec le nom de FDF. Cet objet peut contenir des entrées telles que Fields, F, Status etc. Les entrées les plus couramment utilisées sont Fields, qui indique une liste de champs de contrôle, et F qui contient le nom du fichier PDF a qui appartiennent ces données. Ces entrées sont désignées dans la documentation PDF sous le nom de /F-Key ou /Status-Key. La modification de ces entrées est possible avec les fonctions fdf_set_file() et fdf_set_status(). Les champs sont modifiables avec les fonctions fdf_set_value(), fdf_set_opt() etc.

Pré-requis

Vous aurez besoin du FDF toolkit SDK, disponible sur le site http://partners.adobe.com/asn/acrobat/forms.jsp. Depuis PHP 4.3, vous aurez besoin du SDK version 5.0. La bibliothèque FDF toolkit est disponible sous forme de bibliothèque compilée, éditée par Adobe, sur les systèmes d'exploitation Win32, Linux, Solaris et AIX.

Installation

Vous devez compiler PHP avec --with-fdftk[=DIR].

Note : Si vous rencontrez des problèmes lors de la configuration de FDF avec le support fdftk, vérifiez que le fichier d'en-tête fdftk.h et la bibliothèque libfdftk.so sont à leur place. Le fichier de configuration supporte la hierarchie de dossier de la distribution FDF SDK et l'organisation classique DIR/include et DIR/lib : vous pouvez donc utiliser l'un ou l'autre directement avec la distribution décompressée, ou bien en incluant le fichier d'en-têtes et la bibliothèque appropriée dans votre système, c'est-à-dire dans /usr/local/include et /usr/local/lib. Il ne reste plus qu'à configurer avec --with-fdftk=/usr/local.

Note aux utilisateurs Win32 : Afin d'activer ce module dans l'environnement Windows, vous devez copier les bibliothèques fdftk.dll depuis le dossier DLL de PHP/Win32 dans le dossier système SYSTEM32 de votre machine (par exemple : C:\WINNT\SYSTEM32 ou C:\WINDOWS\SYSTEM32).

Configuration à l'exécution

Cette extension ne définit aucune directive de configuration.

Types de ressources

fdf

La plupart des fonctions FDF nécessite une ressource de type fdf comme premier argument. Une ressource fdf est une structure qui représente un fichier FDF ouvert. Vous pouvez créer des ressources fdf avec les fonctions fdf_create(), fdf_open() et fdf_open_string().

Constantes pré-définies

Ces constantes sont définies par cette extension, et ne sont disponibles que si cette extension a été compilée avec PHP, ou bien chargée au moment de l'exécution.

FDFValue (entier)

FDFStatus (entier)

FDFFile (entier)

FDFID (entier)

FDFFf (entier)

FDFSetFf (entier)

FDFClearFf (entier)

FDFFlags (entier)

FDFSetF (entier)

FDFClrF (entier)

FDFAP (entier)

FDFAS (entier)

FDFAction (entier)

FDFAA (entier)

FDFAPRef (entier)

FDFIF (entier)

FDFEnter (entier)

FDFExit (entier)

FDFDown (entier)

FDFUp (entier)

FDFFormat (entier)

FDFValidate (entier)

FDFKeystroke (entier)

FDFCalculate (entier)

FDFNormalAP (entier)

FDFRolloverAP (entier)

FDFDownAP (entier)

Exemples

Les exemples suivants montrent comment évaluer les données du formulaire.

Exemple 1. Evaluer un document FDF

<?php
// Ouvrir un fichier FDF depuis une chaîne fournie par l'extension PDF
// Le formulaire PDF contient plusieurs champs texte avec les noms de
// volume, date, comment, publisher, preparer, et two boîtes à cocher
// show_publisher et show_preparer.
$fdf = fdf_open_string($HTTP_FDF_DATA);
$volume = fdf_get_value($fdf, "volume");
echo
'Le champ Volume contient la valeur : "<strong>' . $volume . '</strong>"<br />';

$date = fdf_get_value($fdf, "date");
echo
'La valeur du champ date était "<strong>' . $date . '</strong>"<br />';

$comment = fdf_get_value($fdf, "comment");
echo
'La valeur du champ comment était "<strong>' . $comment . '</strong>"<br />';

if (
fdf_get_value($fdf, "show_publisher") == "On") {
 
$publisher = fdf_get_value($fdf, "publisher");
  echo
"La valeur du champ Publisher était : '<strong>" . $publisher . "</strong><br />";
} else
  echo
'La valeur du champ Publisher ne doit pas être affichée.<br />';
 
if (
fdf_get_value($fdf, "show_preparer") == "On") {
 
$preparer = fdf_get_value($fdf, "preparer");
  echo
'La valeur du champ Preparer était  "<strong>' . $preparer . '</strong>"<br />';
} else
  echo
'La valeur du champ Preparer ne doit pas être affiché.<br />';
fdf_close($fdf);
?>

Table des matières
fdf_add_doc_javascript -- Ajoute du code javascript dans un document FDF
fdf_add_template -- Ajoute un template dans le document FDF
fdf_close -- Ferme un document FDF
fdf_create -- Crée un nouveau document FDF
fdf_enum_values -- Appelle une fonction utilisateur à chaque valeur FDF
fdf_errno -- Retourne le code d'erreur de la dernière opération FDF
fdf_error -- Retourne le message d'erreur FDF
fdf_get_ap -- Lit l'apparence d'un champ
fdf_get_attachment -- Extrait un fichier intégré dans un document FDF
fdf_get_encoding -- Lit la valeur de la clé /Encoding
fdf_get_file -- Lit la valeur de la clé /F
fdf_get_flags -- Lit les attributs d'un champ FDF
fdf_get_opt -- Lit une valeur dans un tableau de valeur d'un champ FDF
fdf_get_status -- Lit la valeur de la clé /STATUS
fdf_get_value -- Retourne la valeur d'un champ FDF
fdf_get_version -- Lit le numéro de version de l'API FDF
fdf_header -- Emet les en-têtes HTTP spécifiques à FDF
fdf_next_field_name -- Lit le nom du champ FDF suivant
fdf_open_string --  Lit un document FDF à partir d'une chaîne de caractères
fdf_open -- Ouvre un document FDF
fdf_remove_item -- Configure le cadre FDF de destination pour le formulaire
fdf_save_string -- Retourne un document FDF sous forme de chaîne
fdf_save -- Sauvegarde un document FDF
fdf_set_ap -- Fixe l'apparence d'un champ FDF
fdf_set_encoding -- Modifie l'encodage des caractères
fdf_set_file --  Crée un document PDF pour y afficher des données FDF
fdf_set_flags -- Modifie une option d'un champ
fdf_set_javascript_action -- Modifie l'action javascript d'un champ
fdf_set_on_import_javascript -- Ajoute du code Javascript à être exécuté lorsque Acrobat ouvre un FDF
fdf_set_opt -- Modifie une option d'un champ
fdf_set_status -- Fixe la valeur de la clé /STATUS
fdf_set_submit_form_action -- Modifie l'action d'un formulaire
fdf_set_target_frame -- Configure le cadre de destination pour l'affichage du formulaire
fdf_set_value -- Modifie la valeur d'un champ FDF
fdf_set_version -- Modifie le numéro de version du fichier FDF


Rechercher une fonction PHP

Réseaux sociaux

Vous pouvez modifier vos préférences dans votre profil pour ne plus afficher les interactions avec les réseaux sociaux sur ces pages.

 

Nuage de mots clés

5 mots clés dont 0 définis manuellement (plus d'information...).

Avertissement

Cette page ne possède pas encore de mots clés manuels, ceci est donc un exemple automatique (les niveaux de pertinence sont fictifs, mais les liens sont valables). Pour tester le nuage avec une page qui contient des mots définis manuellement, vous pouvez cliquer ici.

Vous pouvez modifier vos préférences dans votre profil pour ne plus afficher le nuage de mots clés.

 

Références

  1. Consulter le document html Langue du document: fr Manuel PHP : http://be2.php.net, forms data format

Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.

 

Astuce pour imprimer les couleurs des cellules de tableaux : http://www.gaudry.be/ast-rf-450.html
Aucun commentaire pour cette page

© Ce document issu de l′infobrol est enregistré sous le certificat Cyber PrInterDeposit Digital Numbertection. Enregistrement IDDN n° 5329-3693
Document créé le 20/09/06 20:34, dernière modification le Vendredi 17 Juin 2011, 12:12
Source du document imprimé : http://www.gaudry.be/php-rf-ref.fdf.html Document affiché 1 fois ce mois de Juin.
St.Gaudry©07.01.02
Outils (masquer)
||
Recherche (afficher)
Recherche :

Utilisateur (masquer)
Navigation (masquer)
Apparence (afficher)
Stats (afficher)
15832 documents
452 astuces.
549 niouzes.
3099 definitions.
447 membres.
8115 messages.

Document genere en :
0,26 seconde

Mises à jour :
Mises à jour du site
Citation (masquer)
Il a été donné à la volonté de modifier le monde, comme il a appartenu à la PAROLE de le créer.

Alexandre Vinet
 
l'infobrol
Nous sommes le Dimanche 03 Juin 2012, 06:38, toutes les heures sont au format GMT+1.00 Heure, heure d'été (+1)