저희 웹사이트에서 파일 다운로드 서비스를 제공하는 경우 일반적으로 다운로드를 재개할 수 있기를 바랍니다(재개 가능한 다운로드). 전체 파일을 다시 다운로드해야 합니다.
일반적으로 웹 서버(예: Apache)는 기본적으로 재개된 다운로드를 지원합니다. 따라서 웹 서버를 통해 직접 파일 다운로드를 제공하면 별도의 설정 없이 다운로드가 재개되는 이점을 누릴 수 있습니다. 이러한 파일은 웹 서버를 통해 직접 다운로드할 수 있도록 제공되므로 백엔드 스크립트는 다운로드 프로세스를 제어할 수 없습니다. 이는 공용 정적 파일만 제공하는 웹사이트에서는 문제가 되지 않지만, 개인용 동적 파일을 제공해야 하는 웹사이트에서는 웹 서버를 통해 직접 다운로드를 제공하면 요구 사항을 충족할 수 없습니다. 이때 백그라운드 스크립트 프로그램 작성 시 중단점 재개 다운로드에 대한 지원을 추가해야 합니다.
이 기사에서는 PHP를 예로 들어 파일 다운로드를 재개하는 방법을 간략하게 소개합니다.
원칙
다운로드 재개의 원리는 비교적 직관적입니다.
HTTP 프로토콜은 리소스 전체가 아닌 일부를 전송하는 방법을 지정합니다. 예를 들어 파일 크기가 1000바이트인 경우 브라우저는 파일의 처음 300바이트 또는 500~1000바이트만 요청할 수 있습니다. 이렇게 하면 한 번의 요청으로 리소스의 전체 콘텐츠를 전송하는 대신 여러 요청을 할 수 있으며 각각은 콘텐츠의 일부만 요청할 수 있습니다. 이러한 요청이 모두 반환된 후 획득한 콘텐츠를 조각조각 이어붙여 완전한 리소스를 획득합니다.
중단점 재개 가능 다운로드를 구현하려면 위의 HTTP 프로토콜 특성을 활용해야 합니다. 사용자가 다운로드를 일시 중지하면 브라우저는 다운로드 위치를 기록합니다. 사용자가 나중에 다운로드를 다시 시작하면 처음부터 시작할 필요 없이 마지막으로 일시 중지된 위치부터 다운로드를 계속할 수 있습니다.
업적
부분 전송은 필수가 아니며 서버가 지원할 수도 있고 지원하지 않을 수도 있으므로 요청한 리소스가 부분 전송을 지원하는지 여부를 프로그램의 브라우저에 알려야 합니다. 이는 HTTP Accept-Ranges 응답 헤더를 설정하여 수행할 수 있습니다. PHP 코드는 다음과 같습니다.
요청을 받으면 브라우저가 요청하는 리소스 부분을 브라우저 요청에서 추출해야 합니다. 이 정보는 Range 요청 헤더를 통해 전달됩니다. PHP에서는 $_SERVER['HTTP_RANGE']에 저장됩니다. 이 변수가 정의되어 있는지 확인해야 하며, 정의되어 있으면 해당 값을 사용하고, 그렇지 않으면 전체 리소스에 범위를 설정합니다.
1. 시작 위치는 음수가 아닙니다
2. 끝 위치는 시작 위치보다 커야 합니다
3. 시작 위치는 파일 길이에서 1을 뺀 값보다 작아야 합니다. (여기서 위치 인덱스는 0부터 시작하기 때문입니다.)
4. 끝 위치가 파일 길이에서 1을 뺀 값보다 큰 경우 해당 값을 파일 길이에서 1을 뺀 값으로 설정해야 합니다
Range 값이 잘못된 경우 프로그램을 종료하고 브라우저에 알려야 합니다.
다음으로 할 일은 파일의 해당 부분의 내용을 브라우저로 보내는 것입니다. 그러나 여기에는 다음과 같이 여러 HTTP 응답 헤더를 보내는 것이 포함된다는 점에 유의해야 합니다.
/* 파일의 지정된 부분을 출력합니다 */
요약
재개 가능한 파일 다운로드는 실제로 HTTP 프로토콜의 부분 파일 전송 지원을 활용합니다. HTTP 프로토콜의 이 기능은 중단점 재개 가능 다운로드를 구현하는 데 사용될 수 있을 뿐만 아니라 클라이언트 프로그램도 이를 사용하여 다중 스레드 다운로드를 구현할 수 있습니다.
중단점 재개를 구현하는 과정에서는 다양한 HTTP 헤더 정보를 올바르게 설정하는 데 주의가 필요합니다. 잘못된 헤더 정보로 인해 사용자가 다운로드한 파일이 손상되어 사용할 수 없게 됩니다.