Heim >Backend-Entwicklung >PHP-Tutorial >So implementieren Sie den Datei-Download-Breakpoint-Resume in PHP
In diesem Artikel erfahren Sie hauptsächlich, wie Sie die Wiederaufnahme des Dateidownloads in PHP implementieren. Ich hoffe, er kann Ihnen helfen. Wenn unsere Website Dienste zum Herunterladen von Dateien bereitstellt, hoffen wir normalerweise, dass der Download fortgesetzt werden kann (Fortsetzbarer Download), was bedeutet, dass der Benutzer den Download anhalten und den Download zu einem späteren Zeitpunkt an der Pausenstelle fortsetzen kann, ohne ihn neu starten zu müssen. Laden Sie die gesamte Datei herunter.
Normalerweise aktivieren Webserver (wie Apache) standardmäßig die Unterstützung für fortgesetzte Downloads. Wenn Sie also Dateidownloads direkt über den Webserver bereitstellen, können Sie die Vorteile eines fortgesetzten Downloads nutzen, ohne spezielle Konfigurationen vornehmen zu müssen. Da diese Dateien direkt über den Webserver zum Download bereitgestellt werden, kann das Backend-Skript den Downloadvorgang nicht steuern. Für Websites, die nur öffentliche, statische Dateien bereitstellen, stellt dies kein Problem dar, aber für Websites, die private, dynamische Dateien bereitstellen müssen, kann die Bereitstellung von Downloads direkt über den Webserver die Anforderungen nicht erfüllen. Zu diesem Zeitpunkt müssen Sie beim Schreiben des Hintergrundskriptprogramms Unterstützung für das Herunterladen von Haltepunkt-Lebensläufen hinzufügen.
In diesem Artikel wird PHP als Beispiel verwendet, um die Methode zum Fortsetzen von Dateidownloads kurz vorzustellen.
Prinzip
Das Prinzip, den Download fortzusetzen, ist relativ intuitiv.
Das HTTP-Protokoll legt fest, wie ein Teil einer Ressource übertragen wird, nicht die gesamte. Wenn die Größe einer Datei beispielsweise 1000 Byte beträgt, kann der Browser nur die ersten 300 Byte der Datei anfordern, oder nur das 500. bis 1000. Byte. Auf diese Weise können Sie, anstatt den gesamten Inhalt einer Ressource in einer Anfrage zu übertragen, mehrere Anfragen stellen, von denen jede nur einen Teil des Inhalts anfordert. Nachdem alle diese Anfragen zurückgegeben wurden, wird der erhaltene Inhalt Stück für Stück zusammengefügt, um die vollständige Ressource zu erhalten.
Um die Breakpoint-Wiederaufnahme zu implementieren, müssen die oben genannten Eigenschaften des http-Protokolls genutzt werden. Wenn der Benutzer den Download anhält, zeichnet der Browser den heruntergeladenen Speicherort auf. Wenn der Benutzer den Download zu einem späteren Zeitpunkt fortsetzt, kann der Download am zuletzt angehaltenen Speicherort fortgesetzt werden, ohne von vorne beginnen zu müssen.
Implementierung
Da eine teilweise Übertragung nicht obligatorisch ist und der Server sie möglicherweise unterstützt oder nicht, müssen wir dem Browser im Programm mitteilen, ob die angeforderte Ressource eine teilweise Übertragung unterstützt. Dies kann durch Festlegen des HTTP-Accept-Ranges-Antwortheaders erreicht werden. Der PHP-Code lautet wie folgt:
Der Code lautet wie folgt:
header('Accept-Ranges: bytes');
Accept-Ranges: Bytes teilt dem Browser mit, dass die Ressource eine teilweise Übertragung in Bytes unterstützt. Dieser Antwortheader muss an alle Ressourcen angehängt werden, die Teilübertragungen unterstützen.
Wenn wir eine Anfrage erhalten, müssen wir aus der Anfrage des Browsers extrahieren, welchen Teil der Ressource der Browser anfordert. Diese Informationen werden über den Range-Anforderungsheader weitergeleitet. In PHP wird es in $_SERVER['HTTP_RANGE'] gespeichert. Wir müssen prüfen, ob diese Variable definiert ist. Wenn ja, verwenden Sie den Wert, andernfalls legen Sie den Bereich auf die gesamte Ressource fest.
Der Code lautet wie folgt:
$range = "0-". ($content_length-1); if(isset($_SERVER['HTTP_RANGE'])){ $range = $_SERVER['HTTP_RANGE']; }
Als nächstes müssen Sie den Wert von $range analysieren, um zu entscheiden, welcher Teil der Ressource zurückgegeben werden soll. Beispiele für mögliche Werte:
Der Code lautet wie folgt:
100-200 // 第100到第200字节 500- // 第500字节到文件末尾 -1000 // 最后的1000个字节
Hier ist zu beachten, dass Sie nach Erhalt eines Bereichs dessen Wert überprüfen müssen, einschließlich:
1. Die Startposition ist nicht negativ
2. Die Endposition muss größer sein als die Startposition
3. Die Startposition muss kleiner als die Dateilänge minus eins sein (da der Positionsindex hier bei 0 beginnt)
4 Wenn die Endposition größer als die Dateilänge minus eins ist, müssen Sie ihren Wert auf die Dateilänge minus eins setzen
如果Range的取值不合法,则需要终止程序并告知浏览器:
代码如下:
header('HTTP/1.1 416 Requested Range Not Satisfiable');
为了保持文章简洁,具体的校验代码这里就不提供了。下面假定你已经校验了Range的取值,并得到了 $start 和 $end 两个变量,分别表示开始位置和结束位置。
接下来要做的就是把文件的对应部分的内容发送给浏览器。不过要注意的是,这里涉及到需要发送多个HTTP响应头信息,具体如下:
代码如下:
header('HTTP/1.1 206 Partial Content'); header('Accept-Ranges: bytes'); header("Content-Range: bytes $start-$end/$filesize"); $length = $end - $start + 1; header("Content-Length: $length"); /* 输出文件的指定部分 */
这里的$length需要注意一下,它的取值是本次传输的内容的长度,而不是整个文件的长度。另外需要注意的一点是,这里的HTTP状态码是206,不是200。
总结
文件下载的断点续传实际上是利用了HTTP协议中对传输部分文件的支持。而HTTP协议的这一特性不仅可以用于实现断点续传,客户端程序也可以利用它来实现多线程下载。
在实现断点续传的过程中,需要注意正确设置各种HTTP头信息。错误的头信息将导致用户下载到的文件损坏,无法使用。
相关推荐:
Das obige ist der detaillierte Inhalt vonSo implementieren Sie den Datei-Download-Breakpoint-Resume in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!