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
TECHDAYS PARIS 2010 : SHAREPOINT 2010 POUR LES DéVELOPPEURSTECHDAYS PARIS 2010 : SHAREPOINT 2010 POUR LES DéVELOPPEURS par ROMELARD Fabrice
Animé par: Laurent Cotton Le développement dans SharePoint 2010 passe par plusieurs axes qui seront évoqués dans cette session, mais plus particulièrement les développements simples lié au besoin Business Business Connectivity Services Ce BCS es...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice TECHDAYS PARIS 2010 : PLEINIèRE DERNIER JOURTECHDAYS PARIS 2010 : PLEINIèRE DERNIER JOUR par ROMELARD Fabrice
Cette session est la dernière pleinière de ces 3 jours de TechDays Paris 2010. Généralement, cette troisième journée est plus axée sur l'avenir vu par Microsoft. Après un retour sur l'avenir vu par la Science Fiction ou par ...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice UNE JOLIE-HORLOGE ET PAS QU'UN PEU !UNE JOLIE-HORLOGE ET PAS QU'UN PEU ! par neodante
Pour les possesseurs d'iPhone, ça y est Bijin Tokei - qui se traduit littéralement en Français par " Jolie Horloge " - est arrivé et GRATUITEMENT s'il vous plaît ! Après la version Tokyo, Hokkaido, night club, racing, Gal, "pour les mademoiselles'", . voi...
Cliquez pour lire la suite de l'article par neodante TECHDAYS PARIS 2010 : CONNECTEZ VOS DONNéES à SHAREPOINT 2010 AVEC LES BUSINESS CONNECTIVITY SERVICESTECHDAYS PARIS 2010 : CONNECTEZ VOS DONNéES à SHAREPOINT 2010 AVEC LES BUSINESS CONNECTIVITY SERVICES par ROMELARD Fabrice
Animé par: Gaetan Bouveret et Julien Chomarat Business Connectivity Services (BCS) est dans SharePoint 2010 la version 2 de Business Data Catalog (BDC dans SharePoint 2007). Il s'agit de la solution permettant de visualiser des données provenan...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice [DIVERS] SUIVRE VOS SéRIES PRéFéRéS SUR LA TOILE[DIVERS] SUIVRE VOS SéRIES PRéFéRéS SUR LA TOILE par orion
Comme de nombreux geek, je suis un grand amateur de série TV et je rate régulièrement des épisodes de mes séries préférés. Une solution s'offre à vous avec ce merveilleux site : Tv Gorge - www.tvgorge.com Moteur de recherche à l'appui, vous pouvez ...
Cliquez pour lire la suite de l'article par orion
Logiciels
DB-MAIN (9.1.0)DB-MAIN (9.1.0)DB-MAIN is a data-modeling and data-architecture tool. It is designed to help developers and anal... Cliquez pour télécharger DB-MAIN Xilisoft DPG Convertisseur (5.1.37.0120)XILISOFT DPG CONVERTISSEUR (5.1.37.0120)Xilisoft DPG Convertisseur offre aux fans de Nintendo DS une bonne solution leur permettant de dé... Cliquez pour télécharger Xilisoft DPG Convertisseur GraphicsGale (2.01.01)GRAPHICSGALE (2.01.01)GraphicsGale est un logiciel de PixelArt avec de nombreuse fonctionnalités permettant de réalisé ... Cliquez pour télécharger GraphicsGale Architecte 3D (Platinum 2010)ARCHITECTE 3D (PLATINUM 2010)Architecte 3D Platinium vous permet de concevoir facilement les plans votre future maison, de l'é... Cliquez pour télécharger Architecte 3D TeamViewer 5 (TeamViewer 5)TEAMVIEWER 5 (TEAMVIEWER 5)Dépanner un ami,expliquer une manipulation devient un jeu d'enfant.
Prise en main d'un autre ord... Cliquez pour télécharger TeamViewer 5
|