python - 如何在HTML音频源标签中链接Django模型的属性?

标签 python django audio django-forms

感谢Django文档和类似问题的Stack Overflow,我设法弄清楚了这一点,但是我似乎无法在HTML的src标签中将song.audio用作<source>

目标:

显示带有可播放音频文件的歌曲列表。这是从管理/页面上传的只有

我的问题:

当我检查元素时,<source>src属性似乎已成功指向音频文件,但并未将其作为浏览器中的实际可播放“内容”加载。

在Django Runserver控制台中,单击音频播放器的“播放”按钮时的输出为空,但在页面加载时的输出为"GET /songs/media/song_qW9qTXh.mp3 HTTP/1.1" 404 2715将媒体目录移到songs /目录中,的输出仍然是

Chrome检查以下代码的输出:

Image showing the chrome output of the code

我的东西:

资料夹结构:

song-viewer/
| media/
| | song1.mp3
| | song1_w784FH21.mp3
| | song2.mp3
| | song2_r8JJfq0.mp3
|
| song-viewer/
| | __init__.py
| | settings.py
| | urls.py
| | views.py
|
| songs/
| | migrations/
| | templates/
| | | songs/
| | | | song_list.html
| | __init__.pyt
| | admin.py
| | apps.py
| | forms.py
| | models.py
| | urls.py
| | views.py
|
| static/
| | styles.css
| 
| templates/
| | base_layout.html
|
| manage.py
| README.md
| requirements.txt

song-viewer / settings.py:

STATIC_URL = '/static/'
STATICFILES_DIRS = [
    os.path.join(BASE_DIR,'static'),
]
STATIC_ROOT = ''

"""
The above static works fine (am able to link CSS successfully).
However, the below does not. I have shotgunned several different
methods of doing this, including setting MEDIA_ROOT = os.path.join(BASE_DIR, ''), and hiding MEDIA_ROOT
"""
MEDIA_ROOT = ''
MEDIA_URL='/media/'

歌曲查看器/urls.py

from django.contrib import admin
from django.urls import path, include
from . import views
from django.contrib.staticfiles.urls import staticfiles_urlpatterns

urlpatterns = [
    path('admin/', admin.site.urls),
    path('songs/', include('songs.urls')),
    path('', views.homepage)
]

urlpatterns += staticfiles_urlpatterns()

song-viewer / views.py

from django.http import HttpResponse
from django.shortcuts import render

def homepage(request):
    # return HttpResponse('Hello from Home!')
    return render(request, 'homepage.html')

歌曲/模板/歌曲/song_list.html

{% extends 'base_layout.html' %}

{% block content %}
    <h1>Song List</h1>
    <div class="songs-container">
        {% for song in songs %}
            <div class="song">
                <h2><a href="{% url 'songs:detail' slug=song.slug %}">{{ song.title }}</a></h2>
                <p>{{ song.snippet }}</p>
                <p>{{ song.date }}</p>
                <audio controls>
                    <source src="{{ song.audio }}" type="audio/mpeg" >
                    <!-- <source src="{{ song.audio }}" type="audio/mpeg" > NOTE: This gives same output--> 
                </audio>
                {{ song.audio }}
            </div>
        {% endfor %}
    </div>
{% endblock %}

songs / forms.py

from django import forms

class DocumentForm(forms.Form):
    docfile = forms.FileField(
        label='Select an audio file',
        help_text='Must be mp3 format'
    )

songs / models.py

from django.db import models

class Song(models.Model):
    title = models.CharField(max_length=50)
    slug = models.SlugField()
    desc = models.TextField()
    date = models.DateTimeField(auto_now_add=True)
    audio = models.FileField(upload_to='media/')

    def __str__(self):
        return self.title

    def snippet(self):
        return self.desc[:50] + ' ...'

songs / urls.py

from django.urls import path
from . import views

app_name = 'songs'

urlpatterns = [
    path('', views.song_list, name="list"),
    path('<slug>/', views.song_detail, name="detail")
]

songs / views.py

from django.shortcuts import render

from django.template import RequestContext
from django.http import HttpResponse, HttpResponseRedirect
from django.urls import reverse

from .models import Song
from .forms import DocumentForm


def song_list(request):
    if request.method == 'POST':
        form = DocumentForm(request.POST, request.FILES)
        if form.is_valid():
            newdoc = Song(docfile = request.FILES['docfile'])
            newdoc.save()

            return HttpResponseRedirect(reverse('song_list'))
    else:
        form = DocumentForm()

    songs_data = Song.objects.all().order_by('date')
    return render(request, 'songs/song_list.html', {'songs': songs_data, 'form': form})

def song_detail(request, slug):
    return HttpResponse(slug)

最佳答案

我假设您正在开发服务器上运行。您可以使用django.views.static.serve() View 从MEDIA_ROOT提供媒体文件。

歌曲查看器/settings.py

MEDIA_ROOT = os.path.join(BASE_DIR, '')
MEDIA_URL = '/media/'

歌曲查看器/urls.py
from django.contrib import admin
from django.urls import path, include
from . import views
from django.contrib.staticfiles.urls import staticfiles_urlpatterns
from django.conf import settings
from django.conf.urls.static import static

urlpatterns = [
    path('admin/', admin.site.urls),
    path('songs/', include('songs.urls')),
    path('', views.homepage)
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

urlpatterns += staticfiles_urlpatterns()

引用:https://docs.djangoproject.com/en/2.2/howto/static-files/#serving-files-uploaded-by-a-user-during-development

关于python - 如何在HTML音频源标签中链接Django模型的属性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58598164/

相关文章:

audio - 将音频提取到标准输出 [youtube-dl]

android - 在 Android 上播放 amr 中的音频

python - 在 Gtk3 中更改 Gtk.Entry 的背景颜色

python - 每次为 Pandas DataFrame 获取相同的哈希值

python - AWS ECS 上的 PostgreSQL : psycopg2. OperationalError 端口号 5432 无效

java - equencer.startRecording() 没有立即开始? Java MIDI

python - 填充和 reshape pandas 数据框

python - 不能在django模板中使用unicode字符串

python - Django 值错误 : Missing staticfiles manifest entry for 'inline.bundle.js' runserver

python - 如何检查Django表单是否包含任何数据?