Bonjour à tous,
je sollicite grandement votre aide sur ce problème que je ne parviens pas à comprendre. Je me suis renseigné à droite à gauche, y compris sur le site fpdf.org, et il y est dit que cette erreur apparaît si on envoie autre chose au navigateur que le pdf lui même...d'accord ! Seulement, les exemples ne montrent que la manière d'utiliser fpdf directement et ce n'est pas mon cas...
En effet, je veux l'utiliser sur un site, où après avoir constitué un panier, le client doit avoir la possibilité via un bouton de générer un devis sous forme de pdf...
J'ai tout bien installé comme il faut dans un répertoire fpdf à la racine du serveur, j'ai une page d'index centrale dans laquelle j'inclue une page "panier.php" qui elle même inclue ma page "makeDevis.php", je vous met le code de ces trois pages ci dessous :
ma page panier.php :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228 <?php session_start(); header('Content-type: text/html; charset=UTF-8'); echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>Concept Reception</title> <link href="css/style.css" rel="stylesheet" type="text/css"> <script src="scripts/javascript.js" type="text/javascript"></script> <script src="scripts/AC_RunActiveContent.js" type="text/javascript"></script> <script src="scripts/js-global/FancyZoom.js" type="text/javascript"></script> <script src="scripts/js-global/FancyZoomHTML.js" type="text/javascript"></script> </head> <body onload="setupZoom()"> <div id="conteneurPrincipal"> <div id="banniere"></div> <div id="header">'; if(!isset($_SESSION['total'])||$_SESSION['total']==0){ echo '<div align="right">Votre Panier : 0 </div>'; }else{ echo '<div align="right"><a href="index.php?search=panier" class="bouton_panier" >Votre Panier : '.$_SESSION['total'].' </a></div>'; } echo ' </div> <div id="conteneur"> <div id="menu"> <br/><br/>'; include 'SQL_Connect.php'; $Mysql = new Mysql($Serveur = 'localhost', $Bdd = 'concept_reception', $Identifiant = 'root', $Mdp = ''); $Resultats = $Mysql->TabResSQL('SELECT * FROM type'); foreach($Resultats as $valeur){ echo '<center><a class="bouton" href="index.php?search='.$valeur['libelle'].'">'.ucfirst($valeur['libelle']).'</a></center><br/>'; } echo ' </div> <div id="corps">'; if(isset($_GET['search'])){ if($_GET['search']=='admin'||$_GET['search']=='panier'){ include $_SERVER['DOCUMENT_ROOT'].'/'.$_GET['search'].'.php'; }else{ if(isset($_POST['quantite'])&&isset($_POST['id'])){ $Resultats = $Mysql->TabResSQL('SELECT * FROM produit WHERE code='.$_POST['id'].''); if(!isset($_SESSION['panier'])){ $_SESSION['panier']=array(); $_SESSION['panier']['libelle']=array(); $_SESSION['panier']['prix']=array(); $_SESSION['panier']['quantite']=array(); $_SESSION['panier']['url']=array(); } //RAJOUT D'UN ARTICLE AU PANIER OU LE CAS ECHEANT MODIFICATION DE LA QUANTITE D'UN ARTICLE DEJA PRESENT DANS LE PANIER if(count($_SESSION['panier']['libelle'])>0){ for($i=0;$i<count($_SESSION['panier']['libelle']);$i++){ foreach($Resultats as $valeur){ if($_SESSION['panier']['libelle'][$i]==$valeur['libelle']){ $_SESSION['panier']['quantite'][$i]+=$_POST['quantite']; $total=$_POST['quantite']*$valeur['prix']; $_SESSION['total']+=$total; }else{ $_SESSION['panier']['libelle'][count($_SESSION['panier']['libelle'])]=$valeur['libelle']; $_SESSION['panier']['prix'][count($_SESSION['panier']['prix'])]=$valeur['prix']; $_SESSION['panier']['quantite'][count($_SESSION['panier']['quantite'])]=$_POST['quantite']; $_SESSION['panier']['url'][count($_SESSION['panier']['prix'])]=$valeur['url_mini']; if(!isset($_SESSION['total'])){ $total=$_POST['quantite']*$valeur['prix']; $_SESSION['total']=$total; }else{ $total=$_POST['quantite']*$valeur['prix']; $_SESSION['total']+=$total; } } } } }else{ foreach($Resultats as $valeur){ $_SESSION['panier']['libelle'][count($_SESSION['panier']['libelle'])]=$valeur['libelle']; $_SESSION['panier']['prix'][count($_SESSION['panier']['prix'])]=$valeur['prix']; $_SESSION['panier']['quantite'][count($_SESSION['panier']['quantite'])]=$_POST['quantite']; $_SESSION['panier']['url'][count($_SESSION['panier']['url'])]=$valeur['url_mini']; if(!isset($_SESSION['total'])){ $total=$_POST['quantite']*$valeur['prix']; $_SESSION['total']=$total; }else{ $total=$_POST['quantite']*$valeur['prix']; $_SESSION['total']+=$total; } } } echo '<script language="Javascript"> <!-- window.location.replace("http://'.$_SERVER['SERVER_NAME'].'/index.php?search='.$_GET['search'].'&search2='.$_GET['search2'].'"); --> </script>'; } if(!isset($_GET['search2'])){ if(!isset($_GET['search'])){ //TEXTE ACCUEIL }else{ $Resultats = $Mysql->TabResSQL('SELECT * FROM gamme WHERE code_type = ( SELECT code FROM type WHERE libelle = "'.$_GET['search'].'" )'); foreach($Resultats as $valeur){ echo '<div id="ecrin">'; if($valeur['url']!=""){ echo '<a href="index.php?search='.$_GET['search'].'&search2='.$valeur['libelle'].'"><img class="nocontour" src="'.$valeur['url'].'" /></a><br/><br/>'; }else{ echo '<a href="index.php?search='.$_GET['search'].'&search2='.$valeur['libelle'].'">'.$valeur['libelle'].'</a><br/><br/>'; } echo $valeur['libelle']; echo '</div>'; } } }else{ $Resultats = $Mysql->TabResSQL('SELECT * FROM produit WHERE code_gamme = ( SELECT code FROM gamme WHERE libelle = "'.$_GET['search2'].'" )'); foreach($Resultats as $valeur){ echo '<div id="ecrin">'; if($valeur['url']!=""&&$valeur['url_mini']!=""){ echo '<a href="'.$valeur['url'].'"><img class="nocontour" src="'.$valeur['url_mini'].'" /></a><br/><br/>'; }else{ } echo $valeur['libelle'].'<br/>'; echo 'Tarif : '.$valeur['prix'].' '; echo '<form action="#" method="post" enctype="multipart/form-data"> <input type="hidden" name="id" value='.$valeur['code'].' /> Quantité : <input type="text" name="quantite" size="3" /> <input type="submit" value="Ajouter" /> </form>'; echo '</div>'; } } } }else{ //TEXTE ACCUEIL } echo ' </div> </div> <div id="footer"> <p class="admin" style="font-size:9px">Tous <a style="font-size:9px;color:#000;text-decoration:none" class="admin" href="index.php?search=admin">droits</a> réservés. Reproduction Interdite.</p> </div> </div> </body> </html>';
et ma page makeDevis.php :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76 <?php echo ' <br/><br/> <p class="titre">Récapitulatif de votre Panier</p> <br/> <center> <table class="panier" border="1" bordercolor="#000000" > <tr> <th align="center" width="50" > Photo </th> <th align="center" width="300" > Libellé </th> <th align="center" width="100" > Prix Unitaire </th> <th align="center" width="100" > Quantité </th> <th align="center" width="120" > Montant Total </th> </tr>'; if(isset($_POST['hidden'])){ $_SESSION['panier']=array(); $_SESSION['panier']['libelle']=array(); $_SESSION['panier']['prix']=array(); $_SESSION['panier']['quantite']=array(); $_SESSION['panier']['url']=array(); $_SESSION['total']=0; echo '<script language="Javascript"> <!-- window.location.replace("http://'.$_SERVER['SERVER_NAME'].'/index.php"); --> </script>'; }else{ $count=count($_SESSION['panier']['libelle']); for($i=0;$i<$count;$i++){ echo '<tr><td align="center" ><a href="'.$_SESSION['panier']['url'][$i].'"><img class="petite" src="'.$_SESSION['panier']['url'][$i].'" /></a></td> <td align="center" >'.$_SESSION['panier']['libelle'][$i].'</td> <td align="center" >'.$_SESSION['panier']['prix'][$i].' </td> <td align="center" >'.$_SESSION['panier']['quantite'][$i].'</td> <td align="center" >'.$_SESSION['panier']['quantite'][$i]*$_SESSION['panier']['prix'][$i].' </td></tr>'; } if(isset($_POST['devis'])){ include 'makeDevis.php'; } } echo ' </table><br/><br/><br/> <a href="javascript:creerdevis()" class="bouton_panier" >Enregistrer un Devis</a> <a href="javascript:viderpanier()" class="bouton_panier" >Vider le panier</a> </center> <form action="#" id="makedevis" method="post"><input type="hidden" name="devis" value="creerDevis" /></form> <form action="#" id="form" method="post"><input type="hidden" name="hidden" value="viderPanier" /></form>'; ?>
Sur la page d'index, je ne pense pas qu'il soit indispensable de tout lire mais je vous met l'intégralité au cas où, et sur la page panier.php, j'appelle du javascript qui submit le formulaire qui est censé générer mon devis...
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14 <?php define('FPDF_FONTPATH','font/'); ob_start(); require('fpdf/fpdf.php'); $pdf=new FPDF(); $pdf->AddPage(); $pdf->SetFont('Arial','B',16); $pdf->Cell(40,10,'Hello World !'); $pdf->Output(); ?>
Quand ils disent qu'il ne faut rien avoir envoyé d'autre au navigateur que le pdf, ça concerne toutes les pages ou bien uniquement celle sur laquelle je génère le pdf, à savoir ici makeDevis.php.
Je vous remercie d'avance si vous pouvez passer un peu de temps sur ma question![]()
Partager