使用Django框架实现音频上传功能

数据库设计(models.py

python 复制代码
class Music(models.Model):
    """ 音乐 """
    name = models.CharField(verbose_name="音乐名字", max_length=32)
    singer = models.CharField(verbose_name="歌手", max_length=32)

    # 本质上数据库也是CharField,自动保存数据。
    music = models.FileField(verbose_name="音频", max_length=128)

链接(urls.py

python 复制代码
# 音频上传
    path('music/upload/', music.music_upload),
    path('music/add/', music.music_add),

处理代码(music.py

python 复制代码
from django.shortcuts import render, redirect
from app01 import models


def music_upload(request):
    queryset = models.Music.objects.all()
    return render(request, 'music_upload.html', {'queryset': queryset})


from app01.utils.bootstrap import BootStrapModelForm


class UpModelForm(BootStrapModelForm):
    bootstrap_exclude_fields = ['music']

    class Meta:
        model = models.Music
        fields = "__all__"


def music_add(request):
    """ 上传文件和数据 """
    title = "音频上传"
    if request.method == "GET":
        form = UpModelForm()
        return render(request, 'upload_form.html', {"form": form, "title": title})

    form = UpModelForm(data=request.POST, files=request.FILES)
    if form.is_valid():
        # 对于文件:自动保存;
        # 字段 + 上传路径写入到数据库
        form.save()

        return redirect("/music/upload/")
    return render(request, 'upload_form.html', {"form": form, "title": title})

前端页面(music_upload.html)

html 复制代码
{% extends 'layout.html' %}

{% block content %}
    <div class="container">
        <div style="margin-bottom: 10px">
            <a class="btn btn-success" href="/music/add/" target="_blank">
                <span class="glyphicon glyphicon-plus-sign" aria-hidden="true"></span>
                音频上传
            </a>
        </div>

        <div class="panel panel-default">
            <!-- Default panel contents -->
            <div class="panel-heading">
                <span class="glyphicon glyphicon-th-list" aria-hidden="true"></span>
                音频列表
            </div>

            <!-- Table -->
            <table class="table table-bordered">
                <thead>
                <tr>
                    <th>音频</th>
                    <th>音乐名称</th>
                    <th>歌手</th>
                </tr>
                </thead>
                <tbody>
                {% for obj in queryset %}
                    {% if obj.music.name|slice:'-4:' == ".mp3" %}
                        <tr>
                            <td>
                                {% if obj.music.name|slice:'-4:' == ".png" %}
                                    <img src="/media/{{ obj.music }}" style="height: 80px;">
                                {% else %}
                                    <audio controls>
                                        <source src="/media/{{ obj.music }}">
                                    </audio>
                                {% endif %}
                            </td>
                            <td>{{ obj.name }}</td>
                            <td>{{ obj.singer }}</td>
                        </tr>
                    {% endif %}
                {% endfor %}
                </tbody>
            </table>
        </div>
        <div class="clearfix">
            <ul class="pagination" style="float:left;">
                {{ page_string }}
            </ul>
        </div>
    </div>
{% endblock %}

前端页面(upload_form.html)

html 复制代码
{% extends 'layout.html' %}

{% block content %}
    <div class="container">
        <div class="panel panel-default">
            <div class="panel-heading">
                <h3 class="panel-title">{{ title }}</h3>
            </div>
            <div class="panel-body">
                <form method="post" enctype="multipart/form-data" novalidate>
                    {% csrf_token %}
                    {% for field in form %}
                        <div class="form-group">
                            <label>{{ field.label }}</label>
                            {{ field }}
                            <span style="color: red;">{{ field.errors.0 }}</span>
                        </div>
                    {% endfor %}

                    <button type="submit" class="btn btn-primary">提 交</button>
                </form>
            </div>
        </div>
    </div>
{% endblock %}

页面展示

相关推荐
玩电脑的辣条哥2 小时前
Python如何播放本地音乐并在web页面播放
开发语言·前端·python
ew452182 小时前
ElementUI表格表头自定义添加checkbox,点击选中样式不生效
前端·javascript·elementui
suibian52352 小时前
AI时代:前端开发的职业发展路径拓宽
前端·人工智能
Moon.92 小时前
el-table的hasChildren不生效?子级没数据还显示箭头号?树形数据无法展开和收缩
前端·vue.js·html
垚垚 Securify 前沿站2 小时前
深入了解 AppScan 工具的使用:筑牢 Web 应用安全防线
运维·前端·网络·安全·web安全·系统安全
多想和从前一样4 小时前
Django 创建表时 “__str__ ”方法的使用
后端·python·django
工业甲酰苯胺5 小时前
Vue3 基础概念与环境搭建
前端·javascript·vue.js
mosquito_lover16 小时前
怎么把pyqt界面做的像web一样漂亮
前端·python·pyqt
柴柴的小记8 小时前
前端vue引入特殊字体不生效
前端·javascript·vue.js
柠檬豆腐脑9 小时前
从前端到全栈:新闻管理系统及多个应用端展示
前端·全栈