Accueil > > > PUBLIPOSTAGE DOCUMENTS WORDS(AU FORMAT RTF) A PARTIR D'UNE BASE MYSQL
PUBLIPOSTAGE DOCUMENTS WORDS(AU FORMAT RTF) A PARTIR D'UNE BASE MYSQL
Information sur la source
Description
suite a une demande a mon boulot, j'ai créé une sorte d'interface permettant de gérer des documents dont certains sont téléchargeables et d'autres pour du publipostage je ne sais pas trop comment expliquer si ce n'est par son fonctionnement: l'exemple est plus ou moins conçus pour des courriers dans un premier temps gestion des utilisateurs (ou destinataires, expéditeur) on va retrouver les informations personnelles de l'utilisateur de l'application qui pourront servir par exemple pour la partie "expéditeur d'un courrier" et un listing de destinataires "dans mon exemple je les ai appelé "utilisateur".. dans un second temps la gestion documentaire deux tableau differenciant les documents en téléchargement direct et les documents pour publipostage pour finir les formulaires pour le publipostage et pour l'ajout de document a dl/ou pour publipostage.
Source
- <?php
- require('../connexion/_connect.php');//connexion a la base
- function change_carspec($texte)//fonction qui remplace certains caracteres spéciaux tels que les guillemets dans un forma rtf
- {
- $texte= str_replace("'"," \\rquote ",$texte);
- $texte= str_replace('"'," \\ldblquote ",$texte);
- $texte= str_replace('{'," \\{ ",$texte);
- $texte= str_replace('{'," \\} ",$texte);
-
- return $texte;
- }
-
- //initialisation des variables
- $nb_checkbox=count($_POST["checkdest"]);//on compte le nombre de destinataires sélectionnés
- if($nb_checkbox==0){$nb_checkbox=1;}//si aucun on met le compteur à 1
- //variable qui contiendra les pages remplies
- $texte="";
- if($nb_checkbox>1){$texte="{\\rtf1 \n";}//si plusieurs destinataires sélectionnées on met ce code en debut de page.
- //date
- $date_jour=date("d/m/Y");
- //infos utilisateur
- $titre_user="";
- $nom_user="";
- $prenom_user="";
- $adresse_user="";
- $cp_user="";
- $ville_user="";
- $tel_user="";
- $email_user="";
-
- //mes infos
- $my_info_titre="";
- $my_info_nom="";
- $my_info_prenom="";
- $my_info_enseigne="";
- $my_info_adresse="";
- $my_info_cp="";
- $my_info_ville="";
- $my_info_tel="";
- $my_info_fax="";
- $my_info_email="";
-
-
- if(isset($_POST["id_document"]))//si a été choisi un document
- {
- $id_document=$_POST["id_document"];
-
- $SQL_document="SELECT * FROM documents WHERE document_id=$id_document";
- $rc_document=mysql_query($SQL_document);
- $row_document=mysql_fetch_array($rc_document);
- //on récupere les infos du document choisi
- $type_document=$row_document["document_type"];
- $intitule_document=$row_document["document_intitule"];
- $nom_document=$row_document["document_nom"];
- $nomtemp_document=$row_document["document_tempnom"];
-
- // On ouvre le fichier type uploadé
- $rep="./upload_documents/";
- $filename = "$rep$nomtemp_document";
- $temp_file = "$intitule_document - ".date("d-m-Y").".rtf";
- $fp = fopen ( $filename, 'r' );
-
- // On le place en variable $output et on le ferme
- $foutput = fread( $fp, filesize( $filename ) );
- fclose ( $fp );
-
- for ($numpub=0; $numpub < $nb_checkbox; $numpub++)//si plusieurs
- {
- $output=$foutput;
- if(isset($_POST["util_info"])) //si les infos du destinataire sont requises
- {
- if(isset($_POST["checkdest"][$numpub]))//on récupere l'id du destinataire contenu dans le checkbox
- {
- $user_id=$_POST["checkdest"][$numpub];
- $SQLdest="SELECT * FROM user WHERE user_id=$user_id";
- $rc_dest = @mysql_query($SQLdest);
- $row_users=mysql_fetch_array($rc_dest);
-
- $titre_user=$row_users["user_titre"];
- $nom_user=$row_users["user_nom"];
- $prenom_user=$row_users["user_prenom"];
- $adresse_user=$row_users["adresse"];
- $cp_user=$row_users["code_postal"];
- $ville_user=$row_users["ville"];
- $tel_user=$row_users["user_tel"];
- $email_user=$row_users["user_email"];
- }
- }
-
- //si infos personnelles requises
- if(isset($_POST["my_info"]))
- {
- $SQL_my_info="SELECT * FROM my_info WHERE 1";
- $rc_my_info=mysql_query($SQL_my_info);
- $row_my_info=mysql_fetch_array($rc_my_info);
- if(mysql_num_rows($rc_my_info)==0)
- {
- mysql_query("INSERT INTO my_info (my_info_titre) VALUES('')");
- $my_info_id=mysql_insert_id();
- }
- else
- {
- $my_info_titre=$row_my_info["my_info_titre"];
- $my_info_nom=$row_my_info["my_info_nom"];
- $my_info_prenom=$row_my_info["my_info_prenom"];
- $my_info_enseigne=$row_my_info["my_info_enseigne"];
- $my_info_adresse=$row_my_info["my_info_adresse"];
- $my_info_cp=$row_my_info["my_info_cp"];
- $my_info_ville=$row_my_info["my_info_ville"];
- $my_info_tel=$row_my_info["my_info_tel"];
- $my_info_fax=$row_my_info["my_info_fax"];
- $my_info_email=$row_my_info["my_info_email"];
- }
-
- }
-
- // si autres infos requis
- if(isset($_POST["other_info"]))
- {
- $nb_form=$_POST["nb_otherinfo"];
-
- for ($num=1; $num <= $nb_form; $num++)
- {
- if ($_POST["otherinfo_id_$num"]!="")// on récupere les valeurs des champs otherinfo_id_1,otherinfo_id_2,otherinfo_id_3,etc....
- {
- $SQL_other_infos="SELECT * FROM publipostage WHERE publipostage_id=".$_POST["otherinfo_id_$num"];
- $rc_other_infos=mysql_query($SQL_other_infos);
- $row_other_infos=mysql_fetch_array($rc_other_infos);
- $publipostage_keyword=$row_other_infos["publipostage_keyword"];
- $publipostage_texte=$_POST["other_info_$num"];
- $publipostage_texte=str_replace(CHR(10),"\par ", $publipostage_texte);
- $publipostage_texte=change_carspec($publipostage_texte);
- $output = str_replace("$publipostage_keyword", "$publipostage_texte", $output);
- }
- }
- }
-
- // on changes les mots clé par les valeurs des variables
- //si un mot clé n'est pas dans le document , il sera simplement ignoré ;-)
- $output = str_replace("#date#","$date_jour", $output);
- $output = str_replace("#util_titre#","$titre_user", $output);
- $output = str_replace("#util_nom#","$nom_user", $output);
- $output = str_replace("#util_prenom#","$prenom_user", $output);
- $output = str_replace("#util_adresse#","$adresse_user", $output);
- $output = str_replace("#util_cp#","$cp_user", $output);
- $output = str_replace("#util_ville#","$ville_user", $output);
- $output = str_replace("#util_tel#","$tel_user", $output);
- $output = str_replace("#util_email#","$email_user", $output);
-
- $output = str_replace("#mon_titre#","$my_info_titre", $output);
- $output = str_replace("#mon_nom#","$my_info_nom", $output);
- $output = str_replace("#mon_prenom#","$my_info_prenom", $output);
- $output = str_replace("#mon_cp#","$my_info_cp", $output);
- $output = str_replace("#mon_enseigne#","$my_info_enseigne", $output);
- $output = str_replace("#mon_adresse#","$my_info_adresse", $output);
- $output = str_replace("#ma_ville#","$my_info_ville", $output);
- $output = str_replace("#mon_tel#","$my_info_tel", $output);
- $output = str_replace("#mon_fax#","$my_info_fax", $output);
- $output = str_replace("#mon_email#","$my_info_email", $output);
-
- //si on utilisateur >1er alors on ajoute \page qui correspond à saut de page en rtf.
- if($numpub>0){$texte.=" \page ".$output;}else{$texte.=$output;}
- }
-
- //enfin on ouvre le fichier avec les variables implémentées
- $fp = fopen ( $temp_file, 'a+' );
-
- fputs($fp,$texte);
- fclose ( $fp );
- header("Content-type: application/force-download");
- header("Content-disposition: inline; filename=\"$temp_file\";");
- $fh=fopen($temp_file, "rb");
- fpassthru($fh);
- fclose($fh);
- unlink($temp_file);
- }
- else
- {//si aucun document choisi...
- echo "Acces Interdit!";
- }
- mysql_close();
- ?>
<?php
require('../connexion/_connect.php');//connexion a la base
function change_carspec($texte)//fonction qui remplace certains caracteres spéciaux tels que les guillemets dans un forma rtf
{
$texte= str_replace("'"," \\rquote ",$texte);
$texte= str_replace('"'," \\ldblquote ",$texte);
$texte= str_replace('{'," \\{ ",$texte);
$texte= str_replace('{'," \\} ",$texte);
return $texte;
}
//initialisation des variables
$nb_checkbox=count($_POST["checkdest"]);//on compte le nombre de destinataires sélectionnés
if($nb_checkbox==0){$nb_checkbox=1;}//si aucun on met le compteur à 1
//variable qui contiendra les pages remplies
$texte="";
if($nb_checkbox>1){$texte="{\\rtf1 \n";}//si plusieurs destinataires sélectionnées on met ce code en debut de page.
//date
$date_jour=date("d/m/Y");
//infos utilisateur
$titre_user="";
$nom_user="";
$prenom_user="";
$adresse_user="";
$cp_user="";
$ville_user="";
$tel_user="";
$email_user="";
//mes infos
$my_info_titre="";
$my_info_nom="";
$my_info_prenom="";
$my_info_enseigne="";
$my_info_adresse="";
$my_info_cp="";
$my_info_ville="";
$my_info_tel="";
$my_info_fax="";
$my_info_email="";
if(isset($_POST["id_document"]))//si a été choisi un document
{
$id_document=$_POST["id_document"];
$SQL_document="SELECT * FROM documents WHERE document_id=$id_document";
$rc_document=mysql_query($SQL_document);
$row_document=mysql_fetch_array($rc_document);
//on récupere les infos du document choisi
$type_document=$row_document["document_type"];
$intitule_document=$row_document["document_intitule"];
$nom_document=$row_document["document_nom"];
$nomtemp_document=$row_document["document_tempnom"];
// On ouvre le fichier type uploadé
$rep="./upload_documents/";
$filename = "$rep$nomtemp_document";
$temp_file = "$intitule_document - ".date("d-m-Y").".rtf";
$fp = fopen ( $filename, 'r' );
// On le place en variable $output et on le ferme
$foutput = fread( $fp, filesize( $filename ) );
fclose ( $fp );
for ($numpub=0; $numpub < $nb_checkbox; $numpub++)//si plusieurs
{
$output=$foutput;
if(isset($_POST["util_info"])) //si les infos du destinataire sont requises
{
if(isset($_POST["checkdest"][$numpub]))//on récupere l'id du destinataire contenu dans le checkbox
{
$user_id=$_POST["checkdest"][$numpub];
$SQLdest="SELECT * FROM user WHERE user_id=$user_id";
$rc_dest = @mysql_query($SQLdest);
$row_users=mysql_fetch_array($rc_dest);
$titre_user=$row_users["user_titre"];
$nom_user=$row_users["user_nom"];
$prenom_user=$row_users["user_prenom"];
$adresse_user=$row_users["adresse"];
$cp_user=$row_users["code_postal"];
$ville_user=$row_users["ville"];
$tel_user=$row_users["user_tel"];
$email_user=$row_users["user_email"];
}
}
//si infos personnelles requises
if(isset($_POST["my_info"]))
{
$SQL_my_info="SELECT * FROM my_info WHERE 1";
$rc_my_info=mysql_query($SQL_my_info);
$row_my_info=mysql_fetch_array($rc_my_info);
if(mysql_num_rows($rc_my_info)==0)
{
mysql_query("INSERT INTO my_info (my_info_titre) VALUES('')");
$my_info_id=mysql_insert_id();
}
else
{
$my_info_titre=$row_my_info["my_info_titre"];
$my_info_nom=$row_my_info["my_info_nom"];
$my_info_prenom=$row_my_info["my_info_prenom"];
$my_info_enseigne=$row_my_info["my_info_enseigne"];
$my_info_adresse=$row_my_info["my_info_adresse"];
$my_info_cp=$row_my_info["my_info_cp"];
$my_info_ville=$row_my_info["my_info_ville"];
$my_info_tel=$row_my_info["my_info_tel"];
$my_info_fax=$row_my_info["my_info_fax"];
$my_info_email=$row_my_info["my_info_email"];
}
}
// si autres infos requis
if(isset($_POST["other_info"]))
{
$nb_form=$_POST["nb_otherinfo"];
for ($num=1; $num <= $nb_form; $num++)
{
if ($_POST["otherinfo_id_$num"]!="")// on récupere les valeurs des champs otherinfo_id_1,otherinfo_id_2,otherinfo_id_3,etc....
{
$SQL_other_infos="SELECT * FROM publipostage WHERE publipostage_id=".$_POST["otherinfo_id_$num"];
$rc_other_infos=mysql_query($SQL_other_infos);
$row_other_infos=mysql_fetch_array($rc_other_infos);
$publipostage_keyword=$row_other_infos["publipostage_keyword"];
$publipostage_texte=$_POST["other_info_$num"];
$publipostage_texte=str_replace(CHR(10),"\par ", $publipostage_texte);
$publipostage_texte=change_carspec($publipostage_texte);
$output = str_replace("$publipostage_keyword", "$publipostage_texte", $output);
}
}
}
// on changes les mots clé par les valeurs des variables
//si un mot clé n'est pas dans le document , il sera simplement ignoré ;-)
$output = str_replace("#date#","$date_jour", $output);
$output = str_replace("#util_titre#","$titre_user", $output);
$output = str_replace("#util_nom#","$nom_user", $output);
$output = str_replace("#util_prenom#","$prenom_user", $output);
$output = str_replace("#util_adresse#","$adresse_user", $output);
$output = str_replace("#util_cp#","$cp_user", $output);
$output = str_replace("#util_ville#","$ville_user", $output);
$output = str_replace("#util_tel#","$tel_user", $output);
$output = str_replace("#util_email#","$email_user", $output);
$output = str_replace("#mon_titre#","$my_info_titre", $output);
$output = str_replace("#mon_nom#","$my_info_nom", $output);
$output = str_replace("#mon_prenom#","$my_info_prenom", $output);
$output = str_replace("#mon_cp#","$my_info_cp", $output);
$output = str_replace("#mon_enseigne#","$my_info_enseigne", $output);
$output = str_replace("#mon_adresse#","$my_info_adresse", $output);
$output = str_replace("#ma_ville#","$my_info_ville", $output);
$output = str_replace("#mon_tel#","$my_info_tel", $output);
$output = str_replace("#mon_fax#","$my_info_fax", $output);
$output = str_replace("#mon_email#","$my_info_email", $output);
//si on utilisateur >1er alors on ajoute \page qui correspond à saut de page en rtf.
if($numpub>0){$texte.=" \page ".$output;}else{$texte.=$output;}
}
//enfin on ouvre le fichier avec les variables implémentées
$fp = fopen ( $temp_file, 'a+' );
fputs($fp,$texte);
fclose ( $fp );
header("Content-type: application/force-download");
header("Content-disposition: inline; filename=\"$temp_file\";");
$fh=fopen($temp_file, "rb");
fpassthru($fh);
fclose($fh);
unlink($temp_file);
}
else
{//si aucun document choisi...
echo "Acces Interdit!";
}
mysql_close();
?>
Conclusion
les commentaires sur les pages seront ajoutées plus tard là il est trop tard je vais me coucher :-D vous pouvez tester ici: http://foxmaster.info/makedocument/
Historique
- 15 janvier 2008 23:45:30 :
- - correction du bug, + correction de quelques erreurs de frappe...
- 16 janvier 2008 01:03:50 :
- prise en compte des caracteres spéciaux de base
- 16 janvier 2008 01:09:08 :
- mise a jour du zip prise en charge car spec
- 27 janvier 2008 23:22:53 :
- Modification de l'interface et intégration de la possibilité de multipublipostage (plusieurs pages..)
- 27 janvier 2008 23:46:35 :
- petite correction d'un bug dans la validation de modification des documents (accolade en trop :-s)
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Publipostage [ par Fantomas33 ]
Bonjour,je suis sous Linux et l'application que je développe dois faire du publipostage. Le poste client est sous windows/wordQuelqu'un aurait il une
publipostage word [ par mahher ]
Bonjour,Je dois développer une page php qui fait un publipostage entre une base de données MySQL et un document word.Au départ, on
problème:Générer un fichier word [ par EMSIEN ]
J'a envie de générer un fichier word (.doc) et j'ai trouvé ce bout de code en effectuant des recherches,mais ça ne marche pas et &
Publipostage word excel différent [ par teez ]
Les instructions de ce que je voudrais faire sont dans le id.docDites-moi si vous avez une idée de comment faire !C'est ici le fichier à télécharger.h
PHP à Word [ par Slyders ]
Bonjour, je n'ai pas trouvé sur codes-sources, j'ai peut êter mal cherché.Je recherche une méthode pour envoyer des informations saisi par un utilisat
Prtoblème PHP classe COM [ par brian85 ]
Bonjour @ tous,J'ai parcouru les topics là dessus mais bon j'ai pas encore trouvé de solution, j'ai un serveur wamp de dev sous vista avec office inst
lire doc word en php [ par kwantine ]
bonjour je dispose d'une base de données contenant des documents word, txt et pdf. pour pouvoir lire les documents pdf et txt pas de probleme mais je
Publipostage via word en php sous linux [ par Fantomas33 ]
Bonjour,Tout est dans le titre : Publipostage via word en php sous linuxLe problème est que je format word est d'une part binaire et que contrairement
détecter word et version windows [ par 3Rescator ]
Comment détecter si Word, Excel et powerpoint sont installés sur l'ordi du client ?Et aussi, comment détecter si le client utilise Windows XP ?Je sais
réduction d'un doc [ par babybutt ]
bonjour a tous j'aimerais savoir comment on fait pour un document word ou ppt à la taille d'un cadre ?je m'explique, j'ai deux iframe, Cadre 1 c une
|
Derniers Blogs
MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE !MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE ! par Vko
Hier durant une session dédiée aux Techdays 2012, j'ai eu le plaisir d'annoncer la sortie de la Béta 2 de Mishra Reader. C'est quoi ? Pour les utilisateurs, c'est une vraie expérience de lecture de flux RSS sur Windows. Rien à voir avec les produit...
Cliquez pour lire la suite de l'article par Vko [FRAMEWORK 4] LES TASKS ET LE THREAD UI[FRAMEWORK 4] LES TASKS ET LE THREAD UI par fathi
Je viens de passer quelques temps au TechDay's et j'ai pu voir pas mal de session intéressante. Par contre une chose m'a un peu étonné lors de certaines de ces sessions qui abordaient les améliorations du framework .NET (donc le 4.5) : en gros, bea...
Cliquez pour lire la suite de l'article par fathi WORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBEWORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBE par JeremyJeanson
Depuis déjà un an, je conseille vivement les utilisateurs de Workflow Foundation 3 à migrer vers la version 4. L'information qui va suivre ne devrait donc pas trop prendre au dépourvu les personnes qui m'ont suivi. Je profite de ce poste, pour faire le re...
Cliquez pour lire la suite de l'article par JeremyJeanson TECHDAYS PARIS 2012 : NOUVELLES TENDANCES DU POSTE DE TRAVAIL - BRING YOUR OWN PCTECHDAYS PARIS 2012 : NOUVELLES TENDANCES DU POSTE DE TRAVAIL - BRING YOUR OWN PC par ROMELARD Fabrice
Speakers: Thierry Rapatout, Antoine Petit et Xavier Trebbia Cette session entre dans le cadre des RDV Décideurs des TechDays 2012, elle est liée à la consumérisation de l'IT et la mise en place du "DeskTop as a Service" dans de plus en ...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice TECHDAYS PARIS 2012 : SYSTEM CENTER SERVICE MANAGER 2012 VUE D'ENSEMBLETECHDAYS PARIS 2012 : SYSTEM CENTER SERVICE MANAGER 2012 VUE D'ENSEMBLE par ROMELARD Fabrice
Speakers: Julien Marechal, Gautier Confiant, Sébastien MEYER La session débute par le positionnement de la solution System Center par rapport aux concepts d'organisation ITIL. Le portail du catalogue de se...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|