>웹 프론트엔드 >JS 튜토리얼 >PHP 및 AJAX로 생성 후 CSV 파일을 강제로 다운로드하는 방법은 무엇입니까?

PHP 및 AJAX로 생성 후 CSV 파일을 강제로 다운로드하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-24 08:35:02872검색

How to Force Download a CSV File After Creation with PHP and AJAX?

PHP에서 AJAX를 통해 파일을 다운로드하는 방법

웹 애플리케이션으로 작업할 때 서버에서 파일을 다운로드해야 하는 경우가 많습니다. AJAX(비동기 JavaScript 및 XML)는 페이지를 다시 로드하지 않고도 이러한 다운로드를 시작할 수 있는 방법을 제공합니다.

한 가지 방법은 AJAX 기능을 트리거하는 버튼을 만드는 것입니다. 다음 코드 조각은 이 접근 방식을 보여줍니다.

<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>

그러나 여기에서 문제는 PHP로 생성된 CSV 파일을 강제로 다운로드하는 방법입니다. PHP 파일에 제공된 스크립트는 다음과 같습니다.

<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>

문제는 이 스크립트를 실행하면 다운로드가 시작되지 않고 대신 페이지(ajaxDiv 내부)에 CSV 파일의 내용이 표시된다는 것입니다. .

이 문제에 대한 대답은 AJAX가 파일 다운로드용이 아니라는 것입니다. 대신 새 창을 열고 해당 주소를 다운로드 링크로 설정하는 것이 가장 좋습니다. 또는 document.location = .....

을 사용하여 페이지를 다운로드 링크로 직접 리디렉션할 수 있습니다.

위 내용은 PHP 및 AJAX로 생성 후 CSV 파일을 강제로 다운로드하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.