Django 中使用流響應處理視頻的方法
起步
利用 html5 的 <video> 標簽可以播放:
<video width="320" height="240" controls> <source src="/static/video/demo.mp4" type="video/mp4"> 您的瀏覽器不支持Video標簽。 </video>
但是這樣的方式,視頻中的進度條無法使用,而且以靜態(tài)文件方式返回的話,后臺的程序會占用大量的內(nèi)存。
使用響應流的方式能很好的解決這兩個問題。
StreamingHttpResponse
大多數(shù) Django 響應使用 HttpResponse 。這意味著響應的主體內(nèi)置在內(nèi)存中,并以單件形式發(fā)送到 HTTP 客戶端。而如果用 StreamingHttpResponse 的方式則可以以 chunks (部分塊)的方式返回。一個很簡單的例子就是:
from django.http import StreamingHttpResponse def hello(): yield 'Hello,' yield 'there!' def test(request): return StreamingHttpResponse(hello)
根據(jù) WSGI 協(xié)議中的,當服務(wù)器調(diào)用時,應用程序?qū)ο蟊仨毞祷匾粋€可迭代的,產(chǎn)生零個或多個字節(jié)串。因此我們可以通過給服務(wù)器提供生成器來完成流響應的功能。
常見的使用 StreamingHttpResponse 是一些大文件的下載等,利用它還能完成斷點續(xù)傳的功能。
視頻流
使用視頻流時可以從請求頭部中獲得起始字節(jié)數(shù)。

這字段似乎是瀏覽器自動提供的,因為html代碼中,我只需要改下視頻的 src 的從靜態(tài)地址變成路由方式而已。對于響應體而言,也要提供響應體返回的塊的一個范圍:

Content-Range 分別表示了 起始字節(jié)號-終止字節(jié)號/文件總字節(jié) ,該響應體的內(nèi)容包含了文件該范圍內(nèi)的內(nèi)容。處理視頻流的代碼如下:
import re
import os
from wsgiref.util import FileWrapper
from django.http import StreamingHttpResponse
def file_iterator(file_name, chunk_size=8192, offset=0, length=None):
with open(file_name, "rb") as f:
f.seek(offset, os.SEEK_SET)
remaining = length
while True:
bytes_length = chunk_size if remaining is None else min(remaining, chunk_size)
data = f.read(bytes_length)
if not data:
break
if remaining:
remaining -= len(data)
yield data
def stream_video(request, path):
"""將視頻文件以流媒體的方式響應"""
range_header = request.META.get('HTTP_RANGE', '').strip()
range_re = re.compile(r'bytes\s*=\s*(\d+)\s*-\s*(\d*)', re.I)
range_match = range_re.match(range_header)
size = os.path.getsize(path)
content_type, encoding = mimetypes.guess_type(path)
content_type = content_type or 'application/octet-stream'
if range_match:
first_byte, last_byte = range_match.groups()
first_byte = int(first_byte) if first_byte else 0
last_byte = first_byte + 1024 * 1024 * 8 # 8M 每片,響應體最大體積
if last_byte >= size:
last_byte = size - 1
length = last_byte - first_byte + 1
resp = StreamingHttpResponse(file_iterator(path, offset=first_byte, length=length), status=206, content_type=content_type)
resp['Content-Length'] = str(length)
resp['Content-Range'] = 'bytes %s-%s/%s' % (first_byte, last_byte, size)
else:
# 不是以視頻流方式的獲取時,以生成器方式返回整個文件,節(jié)省內(nèi)存
resp = StreamingHttpResponse(FileWrapper(open(path, 'rb')), content_type=content_type)
resp['Content-Length'] = str(size)
resp['Accept-Ranges'] = 'bytes'
return resp
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- Django的HttpRequest和HttpResponse對象詳解
- Django使用HttpResponse返回圖片并顯示的方法
- Django使用httpresponse返回用戶頭像實例代碼
- django rest framework之請求與響應(詳解)
- django從請求到響應的過程深入講解
- 從請求到響應過程中django都做了哪些處理
- Django框架的使用教程路由請求響應的方法
- 在Python的Django框架中用流響應生成CSV文件的教程
- 詳解從Django Rest Framework響應中刪除空字段
- Django 響應數(shù)據(jù)response的返回源碼詳解
- django創(chuàng)建簡單的頁面響應實例教程
- Django框架HttpResponse對象用法實例分析
相關(guān)文章
使用python調(diào)用llama3進行對話的操作步驟
Meta?已將最新的?LLaMa3?進行了開源,因此,我們也可以方便的使用?Python?進行?LLaMa3?模型的調(diào)用和開發(fā),本文給大家介紹了如何使用?python?調(diào)用?llama3?進行對話,需要的朋友可以參考下2024-09-09
django認證系統(tǒng) Authentication使用詳解
這篇文章主要介紹了django認證系統(tǒng) Authentication使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-07-07
Python機器學習之手寫KNN算法預測城市空氣質(zhì)量
KNN(K-Nearest Neighbor)最鄰近分類算法是數(shù)據(jù)挖掘分類(classification)技術(shù)中常用算法之一,本文將介紹如何通過KNN算法實現(xiàn)城市空氣質(zhì)量的預測,感興趣的同學可以了解一下2021-12-12

