一、数据库模型设计
# 在apps/course/models.py中定义如下模型:
from django.db import modelsfrom utils.models import ModelBaseclass Teacher(ModelBase): name = models.CharField(max_length=150, verbose_name="讲师姓名", help_text='讲师姓名') positional_title = models.CharField(max_length=150, verbose_name="职称", help_text='职称') profile = models.TextField(verbose_name="简介", help_text='简介') avatar_url = models.URLField(default="", verbose_name="头像url", help_text='头像url') class Meta: db_table = "tb_teachers" # 指明数据库表名 verbose_name = "讲师" # 在admin站点中显示的名称 verbose_name_plural = verbose_name # 显示的复数名称 def __str__(self): return self.nameclass CourseCategory(ModelBase): name = models.CharField(max_length=100, verbose_name="课程分类名", help_text='课程分类名') class Meta: db_table = "tb_course_category" # 指明数据库表名 verbose_name = "课程分类" # 在admin站点中显示的名称 verbose_name_plural = verbose_name # 显示的复数名称 def __str__(self): return self.nameclass Course(ModelBase): title = models.CharField(max_length=150, verbose_name="课程名", help_text='课程名') cover_url = models.URLField(verbose_name="课程封面图URL", help_text='课程封面图URL') video_url = models.URLField(verbose_name="课程视频URL", help_text='课程视频URL') duration = models.FloatField(default=0.0, verbose_name="课程时长", help_text='课程时长') profile = models.TextField(null=True, blank=True, verbose_name="课程简介", help_text='课程简介') outline = models.TextField(null=True, blank=True, verbose_name="课程大纲", help_text='课程大纲') teacher = models.ForeignKey(Teacher, on_delete=models.SET_NULL, null=True, blank=True) category = models.ForeignKey(CourseCategory, on_delete=models.SET_NULL, null=True, blank=True) class Meta: db_table = "tb_course" # 指明数据库表名 verbose_name = "课程" # 在admin站点中显示的名称 verbose_name_plural = verbose_name # 显示的复数名称 def __str__(self): return self.title
二、百度云VOD点播功能
1.简介
百度 VOD (Video On Demand) 是百度云 BCE (Baidu Cloud Engine) 提供的面向音视频点播的 PaaS (Platform as a Service) 服务平台,为开发者提供音视频文件的存储、管理及播放服务。您无需了解音视频存储、转码、加密、分发、播放等技术细节,即可快速搭建安全可靠、高可定制的点播平台和应用。
2.注册登录上传测试视频
-
打开百度云:
-
可以使用已有的百度云盘账号登录
-
下载百度云APP到手机中,使用刷脸认证
-
-
开通""服务
上传测试视频
# 在mysql数据库中添加你们自己的测试数据(如下数据仅仅是案例,不能正常导入)insert into tb_teachers (name, positional_title, profile, avatar_url, create_time, update_time, is_delete) values('Youkou', 'python高级讲师', '讲师简介', '/media/youkou.jpg', now(), now(), 0);insert into tb_course_category (name, create_time, update_time, is_delete) values('python基础', now(), now(), 0), ('python高级', now(), now(), 0), ('python框架', now(), now(), 0);insert into tb_course (title, cover_url, video_url, duration, `profile`, outline, teacher_id, category_id, create_time, update_time, is_delete) values('你的测试视频1名称', '你的测试视频缩略图URL', '你的测试视频URL', 10.5, '你的测试视频简介', '你的视频大纲', 1, 2, now(), now(), 0),('你的测试视频2名称', '你的测试视频缩略图URL', '你的测试视频URL', '你的测试视频时长为浮点型', '你的测试视频简介', '你的视频大纲', 1, 2, now(), now(), 0);
三、后端功能实现
# 在apps/course/views.py中定义如下类视图:
# 在apps/course/views.py中定义如下类视图:from django.shortcuts import renderfrom . import modelsdef course_list(request): courses = models.Course.objects.only('title', 'cover_url', 'teacher__positional_title').filter(is_delete=False) return render(request, 'course/course.html', locals())
课程详情视图
# 在apps/course/views.py中定义如下类视图:from django.http import Http404from django.shortcuts import renderfrom django.views import Viewfrom . import modelslogger = logging.getLogger('django')class CourseDetailView(View): """ """ def get(self, request, course_id): try: course = models.Course.objects.only('title', 'cover_url', 'video_url', 'profile', 'outline', 'teacher__name', 'teacher__avatar_url', 'teacher__positional_title', 'teacher__profile').\ select_related('teacher').filter(is_delete=False, id=course_id).first() return render(request, 'course/course_detail.html', locals()) except models.Course.DoesNotExist as e: logger.info("当前课程出现如下异常:\n{}".format(e)) raise Http404("此课程不存在!")