>백엔드 개발 >PHP 튜토리얼 >AJAX: 직접 다운로드 또는 서버측 리디렉션을 사용하여 파일 다운로드를 트리거하는 방법은 무엇입니까?

AJAX: 직접 다운로드 또는 서버측 리디렉션을 사용하여 파일 다운로드를 트리거하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-17 00:12:24898검색

How to Trigger a File Download Using AJAX:  Direct Download or Server-Side Redirect?

AJAX 요청으로 파일 다운로드

버튼 클릭 시 "ajax 다운로드 요청"을 시작하려고 할 때 다음과 같은 코드를 구현하는 것이 일반적입니다. 아래:

var xhr = new XMLHttpRequest();
xhr.open("GET", "download.php");
xhr.send();

다음 PHP와 함께 script:

<?
header("Cache-Control: public");
header("Content-Description: File Transfer");
header("Content-Disposition: attachment; filename= file.txt");
header("Content-Transfer-Encoding: binary");    
readfile("file.txt");
?>

그러나 이 접근 방식은 원하는 결과를 얻지 못할 수도 있습니다. 다운로드를 효과적으로 시작하려면 다음 대안 중 하나를 구현하는 것이 좋습니다.

옵션 1: '다운로드' 속성 활용

Firefox 및 Chrome과 같은 최신 브라우저에서는 '다운로드' 속성은 서버측 상호작용 없이 웹페이지 내에서 다운로드를 시작하는 편리한 방법을 제공합니다. 예는 다음과 같습니다.

<a href="file.txt" download="file.txt">Download</a>

옵션 2: AJAX 또는 Window.location을 사용하여 다운로드 스크립트로 이동

'다운로드' 속성이 적합하지 않은 경우 옵션인 경우 AJAX 또는 window.location을 사용하여 다운로드 스크립트로 이동할 수 있습니다. AJAX를 사용하면 비동기 요청을 수행한 다음 성공 콜백 기능을 사용하여 다운로드 스크립트로 리디렉션할 수 있습니다.

$.ajax({
    url: 'download.php',
    type: 'POST',
    success: function() {
        window.location = 'download.php';
    }
});

또는 간단히 window.location을 사용하여 다운로드 스크립트로 이동할 수도 있습니다.

window.location = 'download.php';

AJAX 접근 방식은 어느 정도 유연성을 제공하지만 일반적으로 window.location을 사용하는 것이 더 효율적이고 간단합니다.

위 내용은 AJAX: 직접 다운로드 또는 서버측 리디렉션을 사용하여 파일 다운로드를 트리거하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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