Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [AJAX][PHP] jak Ajaxem po przesłaniu danych zapisać plik na dysk użytkownika?
jhoihkjhkhnkh
post 23.08.2017, 11:21:25
Post #1





Grupa: Zarejestrowani
Postów: 45
Pomógł: 0
Dołączył: 14.07.2017

Ostrzeżenie: (0%)
-----


Teraz robię taką głupawkę, że po naciśnięciu przycisku najpierw idzie Ajax gdzie na podstawie parametrów tworzę plik na serwerze, a potem idzie normalny request gdzie w odpowiedzi zapisuję plik na dysku usera. Wolałbym to robić tylko ajaxem.

teraz jest tak:

  1.  
  2.  
  3. if (//wchodzi ajax){
  4. //wygeneruj plik i zapisz nazwę w sesji
  5. }
  6.  
  7. if(//wchodzi zwykły request){
  8. //odbierz z sesji nazwę pliku i ...
  9. header('Content-Description: File Transfer');
  10. header("Content-type: text/csv; charset=utf-8");
  11. header('Content-Disposition: attachment; filename=' . basename($exportedFile));
  12. header('Content-Transfer-Encoding: binary');
  13. header('Expires: 0');
  14. header('Cache-Control: must-revalidate');
  15. header('Pragma: public');
  16. header('Content-Length: ' . filesize($exportedFile));
  17. flush();
  18. readfile($exportedFile);
  19. unlink($exportedFile);
  20. }
  21.  



i wcześniej ajax

  1. <a href="?action=exp" id="export">
  2. </a>
  3. <script type="text/javascript">
  4. $("#export").click(function () {
  5. $.ajax({
  6. url: "../admin/shop.php",
  7. data: {
  8. action: 'exp',
  9. tableParams: tableParams
  10. }
  11. })
  12. });



Problem polega na tym, że zdarza się że szybszy jest request "zwykły" a potem idzie ajax. Mogłoby tak zostać ale musiałbym jakoś zmusić by najpierw szedł ajax a po nim zwykły request. Muszę to robić ajaxem bo dane na podstawie którym mam wygenerować plik są widoczne tylko przez javascript

Ten post edytował jhoihkjhkhnkh 23.08.2017, 11:57:18
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
jhoihkjhkhnkh
post 23.08.2017, 12:42:14
Post #2





Grupa: Zarejestrowani
Postów: 45
Pomógł: 0
Dołączył: 14.07.2017

Ostrzeżenie: (0%)
-----


Cytat(nospor @ 23.08.2017, 12:53:57 ) *
No to wysylaj zwykly request dopiero gdy AJAX sie skonczy. Masz przeciez zdarzenie onsuccess dla AJAXow i wiesz kiedy sie skonczyly

zrobiłem tak:

  1. $("#export").click(function () {
  2. $.ajax({
  3. url: "../admin/shop.php",
  4. data: {
  5. action: 'exp',
  6. tableParams: tableParams
  7. },
  8. success: function() {
  9. $.get( "//export()" );
  10. }
  11. })
  12. });


przy debugowaniu widzę jak za drugim razem wpada w ten fragment kodu (który wcześniej skutecznie zapisywał plik na dysk usera) gdzie ustawiany jest header (i w trakcie debugowania widzę że ten plik istnieje na serwerze)
  1. header('Content-Description: File Transfer');
  2. header("Content-type: text/csv; charset=utf-8");
  3. header('Content-Disposition: attachment; filename=' . basename($exportedFile));
  4. header('Content-Transfer-Encoding: binary');
  5. header('Expires: 0');
  6. header('Cache-Control: must-revalidate');
  7. header('Pragma: public');
  8. header('Content-Length: ' . filesize($exportedFile));
  9. flush();
  10. readfile($exportedFile);
  11. unlink($exportedFile);

ale finalnie nie zapisuje żadnego pliku na dysk usera.

Ten post edytował jhoihkjhkhnkh 23.08.2017, 13:00:05
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 14.08.2025 - 22:08