Hallo!
Du "erstellst" die Datei nicht indem Du sie auf dem Server speicherst,
sondern indem Dein Script diese Datei an den "anfragenden" Client
sendet... Du hast also 2 PHP-Scripts
ScriptA (HTML) index.html
<A HREF='getcsv.php'>Lade das CSV runter!!!</A>
ScriptB (PHP) getcsv.php
<?PHP
// Hier kommen die Headerdaten (Weiter unten erklärt)
....
// Natürlich hier die Daten auslesen!
echo '"Name1", "Vorname1"\n';
echo '"Name2", "Vorname2"\n';
?>
Der Anfang klar???
Das Problem liegt jetzt da, dass das getcsv.php keinen Download
startet, sondern dieses "Textfile" im Browser darstellt.
Dafür kann man Headerdaten nutzen. Wir teilen so dem Browser
Steuergrössen mit. Damit kann man diverse Standardgrössen
überschreiben. Bsp: Dateiname, Dateigrösse, Dateityp, Mimetype, ...
Ich empfehle folgende Headers für ein CSV-Download:
<?PHP
header('Content-Type: text/x-csv'); // Mime-Type
header('Content-Disposition: attachment; filename="datei.csv"');
// Als Attachment mit dem Dateinamen datei.csv
header('Expires: 0'); // Kein Caching!
?>
Und zwar bevor irgend ein Text jemals ausgegeben wurde, sonst
klappts nicht und gibt auch ne schöne Fehlermeldung :)
Und schon kann man es gebrauchen .)
Miro Dietiker
MD Systems
als Antwort auf: [#10423]
(Dieser Beitrag wurde von Miro Dietiker am 31. Aug 2002, 21:29 geändert)