Cara Muat Turun Fail melalui AJAX dalam PHP
Apabila bekerja dengan aplikasi web, selalunya perlu memuat turun fail daripada pelayan. AJAX (JavaScript Asynchronous dan XML) menyediakan cara untuk memulakan muat turun sedemikian tanpa memuatkan semula halaman.
Satu kaedah melibatkan mencipta butang yang mencetuskan fungsi AJAX. Coretan kod berikut menunjukkan pendekatan ini:
<code class="php">function csv(){ $ajaxRequest = ajax(); $postdata = "data=" . document.getElementById("id").value; $ajaxRequest.onreadystatechange = function(){ var ajaxDisplay = document.getElementById('ajaxDiv'); if($ajaxRequest.readyState == 4 && $ajaxRequest.status==200){ ajaxDisplay.innerHTML = $ajaxRequest.responseText; } } $ajaxRequest.open("POST","csv.php",false); $ajaxRequest.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); $ajaxRequest.send($postdata); }</code>
Walau bagaimanapun, persoalannya di sini ialah cara memuat turun paksa fail CSV yang dibuat selepas ia dibuat oleh PHP. Skrip yang disediakan dalam fail PHP adalah seperti berikut:
<code class="php">$fileName = 'file.csv'; $downloadFileName = 'newfile.csv'; if (file_exists($fileName)) { header('Content-Description: File Transfer'); header('Content-Type: text/csv'); header('Content-Disposition: attachment; filename='.$downloadFileName); ob_clean(); flush(); readfile($fileName); exit; } echo "done";</code>
Masalahnya ialah menjalankan skrip ini tidak memulakan muat turun tetapi sebaliknya memaparkan kandungan fail CSV dalam halaman (di dalam ajaxDiv) .
Jawapan kepada isu ini ialah AJAX tidak bertujuan untuk muat turun fail. Sebaliknya, amalan terbaik ialah membuka tetingkap baharu dan menetapkan alamatnya kepada pautan muat turun. Sebagai alternatif, anda boleh mengubah hala terus halaman ke pautan muat turun menggunakan document.location = .....
Atas ialah kandungan terperinci Bagaimana Memaksa Muat Turun Fail CSV Selepas Penciptaan dengan PHP dan AJAX?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!