【django】简易视频播放功能

前台

{% block content %}
    <video width="640" height="480" controls>
        <source id="media" src="/video/test.mp4/" type="video/mp4">
    </video>

{% endblock %}

路由

# video/是播放视频的页面
path('video/', video.video),
    
# 这里的<arg_path>作为第二个参数传递到stream_video函数中去,意义就是视频文件的路径名
path('video/<arg_path>/', video.stream_video),

后台

views.py

def video(request):
    return render(request, 'video/video.html', {})


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, arg_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)
    # 这里规定存放视频文件夹
    path = 'E:\\video\\' + arg_path
    print(path)
    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 * 10
        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:
        resp = StreamingHttpResponse(FileWrapper(open(path, 'rb')), content_type=content_type)
        resp['Content-Length'] = str(size)
    resp['Accept-Ranges'] = 'bytes'
    return resp

  • 4
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,关于 Django 简易视频播放功能,您可以通过以下步骤实现: 1. 安装 `django-embed-video` 库 您可以使用 `pip` 命令来安装该库: ``` pip install django-embed-video ``` 2. 配置 `settings.py` 文件 在 `INSTALLED_APPS` 中添加 `embed_video`: ```python INSTALLED_APPS = [ # ... 'embed_video', ] ``` 在 `MIDDLEWARE` 中添加以下代码: ```python MIDDLEWARE = [ # ... 'django.middleware.clickjacking.XFrameOptionsMiddleware', 'django.middleware.common.CommonMiddleware', ] ``` 3. 在 models.py 中创建数据库模型 例如,我们创建一个 `Video` 模型: ```python from django.db import models from embed_video.fields import EmbedVideoField class Video(models.Model): title = models.CharField(max_length=200) video = EmbedVideoField() ``` 注意要导入 `EmbedVideoField`。 4. 创建表单 可以使用 Django 的内置表单来创建一个添加视频的表单: ```python from django import forms from .models import Video class VideoForm(forms.ModelForm): class Meta: model = Video fields = ('title', 'video',) ``` 5. 创建视图函数 在视图函数中,我们可以使用 `VideoForm` 表单创建视频,以及将视频传递给模板: ```python from django.shortcuts import render from .models import Video from .forms import VideoForm def video(request): if request.method == 'POST': form = VideoForm(request.POST) if form.is_valid(): video = form.save(commit=False) video.save() else: form = VideoForm() videos = Video.objects.all() return render(request, 'video.html', {'form': form, 'videos': videos}) ``` 6. 创建模板 最后,我们需要创建一个名为 `video.html` 的模板,以显示所有视频和表单。可以使用以下代码: ``` {% extends 'base.html' %} {% block content %} <h1>Video Gallery</h1> <h3>Add Video</h3> <form method="post" enctype="multipart/form-data"> {% csrf_token %} {{ form.as_p }} <button type="submit">Add</button> </form> <hr> <h3>Videos</h3> <ul> {% for video in videos %} <li>{{ video.title }}</li> {{ video.video }} {% endfor %} </ul> {% endblock %} ``` 这样,您就可以在 Django 中实现简易视频播放功能了!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值