Ajax를 사용하여 단일 형식으로 데이터와 파일 모두 업로드
jQuery 및 Ajax를 사용하여 양식과 상호작용할 때 다음 중 하나를 제출하는 것이 일반적입니다. 데이터 또는 파일(동시에는 불가능) 이는 두 가지 유형의 콘텐츠를 모두 업로드해야 할 때 문제가 될 수 있습니다.
문제 설명
가장 큰 문제는 제출 전에 데이터와 파일을 수집하는 방식이 다르다는 것입니다. . 데이터는 일반적으로 .serialize() 메소드를 사용하여 직렬화되고 파일은 FormData 객체를 사용하여 처리됩니다.
솔루션
다음을 통해 데이터와 파일을 하나의 형식으로 업로드하려면 Ajax에서는 FormData의 강력한 기능을 활용할 수 있습니다. 이 개체를 사용하면 두 가지 유형의 콘텐츠를 쉽게 결합할 수 있습니다. 방법은 다음과 같습니다.
<form>
$("form#datafiles").submit(function(e) { e.preventDefault(); var formData = new FormData(this); // Gather both data and files into a single FormData object $.ajax({ url: window.location.pathname, // Your PHP endpoint URL type: 'POST', data: formData, success: function(data) { alert(data); // Output the response from your PHP script }, cache: false, contentType: false, processData: false }); });
PHP 스크립트
서버 측에서 PHP 스크립트는 귀하가 제출한 데이터와 파일 모두에 액세스할 수 있습니다. 형태. $_POST 및 $_FILES를 사용하여 이 정보를 검색할 수 있습니다.
<?php // Display contents of $_POST print_r($_POST); // Display contents of $_FILES print_r($_FILES); ?>
결론
FormData를 활용하면 단일 파일에서 데이터와 파일을 모두 쉽게 제출할 수 있습니다. Ajax를 사용하여 양식을 만듭니다. 이 접근 방식은 양식을 간소화하고 파일 및 데이터 관리 효율성을 향상시킵니다.
위 내용은 Ajax를 사용하여 단일 형식으로 데이터와 파일을 동시에 업로드하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!