Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [AJAX][PHP] jak Ajaxem po przesłaniu danych zapisać plik na dysk użytkownika?
jhoihkjhkhnkh
post
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
Post #2





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

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


(edit: działa)

jasna cholera, lokalnie działa, ale na serwerze już nie.

już wkleję całość by nie było wątpliwości

  1. function export()
  2. {
  3. $tableParams = $_GET['tableParams'] (IMG:style_emoticons/default/questionmark.gif) false;
  4. if (!$session->get('csvFile') and !$tableParams){
  5. showList();
  6. }
  7.  
  8. if (!$session->get('csvFile') and $tableParams){
  9. // $session->set('csvFile')
  10. }
  11.  
  12. if($session->get('csvFile')) {
  13. $exportedFile = $session->get('csvFile');
  14. unset($_SESSION['csvFile']);
  15. //zapis pliku na dysk lokalny usera, wg https://stackoverflow.com/a/11316004/6827096
  16. header('Content-Description: File Transfer');
  17. header("Content-type: text/csv; charset=utf-8");
  18. header('Content-Disposition: attachment; filename=' . basename($exportedFile));
  19. header('Content-Transfer-Encoding: binary');
  20. header('Expires: 0');
  21. header('Cache-Control: must-revalidate');
  22. header('Pragma: public');
  23. header('Content-Length: ' . filesize($exportedFile));
  24. flush();
  25. readfile($exportedFile);
  26. unlink($exportedFile);
  27. }
  28. }


  1. <a href="" id="export">
  2. <button >
  3. </button>
  4. </a>
  5. <script type="text/javascript">
  6. $("#export").click(function () {
  7. $.ajax({
  8. url: "//export()",
  9. data: {
  10. action: 'exp',
  11. tableParams: tableParams
  12. }
  13. }).success(function(){
  14. document.location.href='?action=exp';
  15. })
  16. });
  17. </script>




edit:

zmieniłem
<a href="" id="export"><button ></button></a>

na
<p id="export"></p>

i chwilowo działa.

Ten post edytował jhoihkjhkhnkh 23.08.2017, 16:25:47
Go to the top of the page
+Quote Post

Posty w temacie


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

 



RSS Aktualny czas: 16.10.2025 - 12:37