AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

[php] "Speichern unter"-Dialog?

Ein Thema von Grolle · begonnen am 9. Mai 2006 · letzter Beitrag vom 10. Mai 2006
Antwort Antwort
Seite 1 von 2  1 2      
Grolle

Registriert seit: 5. Nov 2004
Ort: Coesfeld
1.268 Beiträge
 
Delphi 2010 Professional
 
#1

[php] "Speichern unter"-Dialog?

  Alt 9. Mai 2006, 20:52
Hallo,

wie realisiere ich mit php einen "Speichern unter"-Dialog? Ich möchte eine
Datenbank in eine *.csv-Datei exportieren. Den Export mache ich wie folgt:
Delphi-Quellcode:
<?php

include "connect.inc.php";
$fp = fopen('file.csv', 'w');
$sql = "SELECT name, vorname, strasse FROM adressbuch";
$res = mysql_query($sql) or die("Fehler:
" . mysql_error() . "
$sql");
while($row = mysql_fetch_row($res)){
    $line = implode(';', $row);
    fwrite($fp, $line . "\r\n");
}

fclose($fp);
?>
Viele Grüße,

  Mit Zitat antworten Zitat
Benutzerbild von faux
faux

Registriert seit: 18. Apr 2004
Ort: Linz
2.044 Beiträge
 
Turbo Delphi für Win32
 
#2

Re: [php] "Speichern unter"-Dialog?

  Alt 9. Mai 2006, 20:55
Hallo!

Biete sie einfach zum Download an.

Beispiel:
Code:
header("Content-type: text/csv");
header("Content-Disposition: attachment; filename=".$filename);
Grüße
Faux
Faux Manuel
Wer weiß, dass er nichts weiß, weiß mehr, als der der nicht weiß, dass er nichts weiß.
GoTrillian
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: [php] "Speichern unter"-Dialog?

  Alt 9. Mai 2006, 20:57
Code:
header( 'Content-Disposition: attachment; filename='.$fname);
[Edit: War zu langsam]
Markus Kinzler
  Mit Zitat antworten Zitat
Grolle

Registriert seit: 5. Nov 2004
Ort: Coesfeld
1.268 Beiträge
 
Delphi 2010 Professional
 
#4

Re: [php] "Speichern unter"-Dialog?

  Alt 9. Mai 2006, 20:59
Hi,

muss ich das nach dem fclose($fp) setzen?
Bin PHP-Neuling

Viele Grüße..

  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: [php] "Speichern unter"-Dialog?

  Alt 9. Mai 2006, 20:59
Nein vor deinen Code.
Markus Kinzler
  Mit Zitat antworten Zitat
Grolle

Registriert seit: 5. Nov 2004
Ort: Coesfeld
1.268 Beiträge
 
Delphi 2010 Professional
 
#6

Re: [php] "Speichern unter"-Dialog?

  Alt 9. Mai 2006, 21:05
Hi,

das klappt zwar, aber jetzt wird nix mehr in die Datei geschrieben ?!?

  Mit Zitat antworten Zitat
Flare

Registriert seit: 26. Jan 2006
Ort: Leipzig
529 Beiträge
 
Delphi 7 Professional
 
#7

Re: [php] "Speichern unter"-Dialog?

  Alt 9. Mai 2006, 21:11
Eigentlich müsste es danach geschrieben werden, weil die Datei innerhalb deines Skriptes erstellt wird, also nachdem der Download gestartet hat, dann kannst du wenig runterladen
Ich glaube (ich arbeite nicht mit header() direkt), dass er beim Aufruf von
Code:
header( 'Content-Disposition: attachment; filename='.$fname);
sofort den Download startet.


Flare
Willy Scheibel
  Mit Zitat antworten Zitat
Benutzerbild von faux
faux

Registriert seit: 18. Apr 2004
Ort: Linz
2.044 Beiträge
 
Turbo Delphi für Win32
 
#8

Re: [php] "Speichern unter"-Dialog?

  Alt 9. Mai 2006, 21:12
Poste mal deinen Code.

Zitat von Flare:
Ich glaube (ich arbeite nicht mit header() direkt), dass er beim Aufruf von
Code:
header( 'Content-Disposition: attachment; filename='.$fname);
sofort den Download startet.
Weiß auch nicht ob da so ist, aber selbst wenn das so wäre, wäre der Download erst abgeschlossen, wenn die Seite fertig geladen ist, also ists auch wieder ok.

Grüße
Faux
Faux Manuel
Wer weiß, dass er nichts weiß, weiß mehr, als der der nicht weiß, dass er nichts weiß.
GoTrillian
  Mit Zitat antworten Zitat
noch_ein_hannes

Registriert seit: 18. Sep 2003
130 Beiträge
 
#9

Re: [php] "Speichern unter"-Dialog?

  Alt 9. Mai 2006, 21:14
Du brauchst gar keine Datei zu schreiben, denn mit dem Header lenkst Du die Ausgabe ja um:
Delphi-Quellcode:
header( 'Content-Disposition: attachment; filename='.$fname);
$sql = "SELECT name, vorname, strasse FROM adressbuch";
$res = mysql_query($sql) or die("Fehler:
" . mysql_error() . "
$sql");
while($row = mysql_fetch_row($res)){
    $line = implode(';', $row);
    echo $line . "\r\n";
}
wenn Du schon eine Datei hast, kannst Du sie (nach dem Header) einfach mit readfile() ausgeben ...
- everything is possible -
  Mit Zitat antworten Zitat
Benutzerbild von DGL-luke
DGL-luke

Registriert seit: 1. Apr 2005
Ort: Bad Tölz
4.149 Beiträge
 
Delphi 2006 Professional
 
#10

Re: [php] "Speichern unter"-Dialog?

  Alt 9. Mai 2006, 21:14
nene! Erst der header, dann die Infos.

Also:

- Daten bereithalten/erzeugen/öffnen
- Header schicken
- Daten schicken

für weitere Analyse bräuchten wir ein bisschen Code, Grolle.

//roter kasten... ja...

EDIT: nein, ein Header leitet gar nix um. Wenn er nicht der Location-Header ist.
Der Content-Disposition-Header sagt nur, welcher Datentyp (genauer MIME-typ) zu erwarten ist, damit der User Agent entsprechend reagieren kann.
Lukas Erlacher
Suche Grafiktablett. Spenden/Gebrauchtangebote willkommen.
Gotteskrieger gesucht!
For it is the chief characteristic of the religion of science that it works. - Isaac Asimov, Foundation I, Buch 1
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:30 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz