【问题标题】:Flowplayer not working with amazon s3 signed urlsFlowplayer 不适用于亚马逊 s3 签名的网址
【发布时间】:2012-12-20 00:04:33
【问题描述】:

Flowplayer 似乎不喜欢 url 中的查询字符串。为什么会这样:

{% extends "base.html" %}
{% block extra_head %}
<!-- 1. jquery library -->
<script
  src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js">
</script>

<!-- 2. flowplayer -->
<script src="http://releases.flowplayer.org/5.2.1/flowplayer.min.js"></script>

<!-- 3. skin -->
<link rel="stylesheet" type="text/css"
   href="http://releases.flowplayer.org/5.2.1/skin/minimalist.css" />
{% endblock %}
{% block content %}
    <div class="flowplayer">
        <video src="https://mybucketname.s3.amazonaws.com/videos/Quixotic_2012.mp4"></video>
    </div>

{% endblock %}

但这不是:

{% extends "base.html" %}
{% block extra_head %}
<!-- 1. jquery library -->
<script
  src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js">
</script>

<!-- 2. flowplayer -->
<script src="http://releases.flowplayer.org/5.2.1/flowplayer.min.js"></script>

<!-- 3. skin -->
<link rel="stylesheet" type="text/css"
   href="http://releases.flowplayer.org/5.2.1/skin/minimalist.css" />
{% endblock %}
{% block content %}
    <div class="flowplayer">
        <video src="https://mybucketname.s3.amazonaws.com/videos/Quixotic_2012.mp4?Signature=mrsCPFcFOK5tceBieh5Ii%2BewNVk%3D&Expires=1355962607&AWSAccessKeyId=1VDAPQXESPKD9EKFT2R2"></video>
    </div>

{% endblock %}

什么是让 flowplayer 使用签名网址的好方法?

编辑: 我在 Javascript 控制台中收到此错误: 不支持“video/mp4”的 HTTP“Content-Type”。媒体资源https://mybucketname.s3.amazonaws.com/videos/Quixotic_2012.mp4?Signature=hVStvUqQLIAhY4h%2Bp839LTNmvDo%3D&Expires=1355975423&AWSAccessKeyId=1VDAPQXESPKD9EKFT2R2 加载失败。

我已验证签名正确。将链接粘贴到地址栏中时,该链接有效。

更新: 如果我将 type="video/mp4" 添加到视频标签,它会起作用。现在我只需要弄清楚如何在 Django 模板中动态确定文件对象的 mimetype。希望它像 {{ object.video.mimetype }} 一样简单,尽管这本身是不正确的。

【问题讨论】:

  • 关于这个问题的任何细节?您是否在 Javascript 控制台上遇到特定错误?您能否查看您的浏览器是否通过错误的 URL 请求视频(检查 Firebug 或其他 Web 开发工具的网络选项卡)。显然:您确定您的 URL 签名正确,即直接粘贴到地址栏时是否有效?
  • 编辑回答您的问题。提前感谢您提供的任何帮助。

标签: django amazon-s3 flowplayer


【解决方案1】:

为了让它工作,我必须在视频标签中添加一个 mime 类型,如下所示:

<video type="video/mp4" src="https://mybucketname.s3.amazonaws.com/videos/Quixotic_2012.mp4?Signature=mrsCPFcFOK5tceBieh5Ii%2BewNVk%3D&Expires=1355962607&AWSAccessKeyId=1VDAPQXESPKD9EKFT2R2"></video>

使用 django 来动态获取 mimetype,我必须创建一个模板标签。 urlparse 用于从链接中剥离查询字符串,以便 mimetypes.guess_type 可以确定正确的 mime_type。

#custom_tags.py

import mimetypes
from django import template
from django.conf import settings
from urlparse import urlparse

register = template.Library()

@register.filter
def mimetype(value):
    return mimetypes.guess_type(urlparse(value).path, strict=True)[0]

然后把它放在模板中:

{% load custom_tags %}

 <video type="{{ object.video.url|mimetype }}" src="{{ object.video.url }}"></video>

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2014-08-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-06-24
    • 2011-04-17
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多