现在开始,我们要加快进度,快马加鞭制作我们的云盘。
我们现在先别管会员制,我们先假设制作一个人用的云盘,假设我们进入主页就是已经登录好的云盘界面,我们思考一下,这个页面上需要哪些东西。
因为是一个云盘,所以,我们肯定需要一个列表,上面列着我们存在云盘上的文件,然后点击他们可以下载,然后每个文件右边有个删除按钮用来删除文件,主页还有一个上传按钮用来上传文件,基本上只要把上面的功能实现了,那我们的云盘差不多就完成了。可以的话,我们希望最好文件右边还有一栏显示文件上传的日期。
这时你可能开始慌了,隐约觉得我们开始需要涉及数据库方面的东西了,没错,因为这涉及到存放文件数据了,我们想想,云盘需要什么样的数据结构?
云盘需要的数据最最最主要是两个,第一,这个文件的名字,第二,这个文件的路径。实际上也只有一个,那就是路径,比如我们之前的logo.png文件,路径是myCloud/static/logo.png,有这个路径也就可以知道文件名了。当然,我们还可以附加一个数据,那就是上传时间(这是可有可无的,我们的云盘高端点就加上,不加也没关系)
也就是说,我们需要把每次把一种叫文件的数据存进数据库顺便存一下它存入数据库的时间日期,这样一来,我们每次进入主页,我们就可以根据数据库里面文件数据的文件名属性信息找出来列到我们主页的列表里,然后文件的路径做成链接可以是我们点击文件名的时候链接到这个文件的路径进行下载。
对于新手来说,这时候可能就两眼懵逼了,什么数据库,怎么使用数据库,这个名词天天听到,可是到底是一个什么 东西的存在?数据库其实大家或多或少都会有概念的,网络服务的数据库也跟我们平时用来处理数据的东西差不多,比如excel。大家觉得难的其实是他的接口,简单地说就是不知道怎么用数据库,平时我们使用excel,鼠标点击就打开,键盘输入数据,然后点击保存,关闭退出。而使用网络数据库,这些基本都要靠代码来完成,怎么往里面写数据,怎么从里面取出数据,其实也不难学,无非是一些命令罢了,得花一定时间。
如果,你在学习传统的网页制作方式,可能到这里,很多人就知难而退了,我一个业余爱好者做一个网页玩玩,你居然想让我学习数据库这么专业的东西?太浪费时间了!莫慌!django就是这样一个拯救你的宝贵时间的存在,django直接把数据库封装了,使用了一个叫ORM映射的东西,把数据库里面的数据映射成了一个个的对象。直接讲ORM可能得费老半天的时间,我们就在实践中学习吧。
由于我们的云盘肯定是要储存数据的,我们首先要选择一个数据库,django支持的数据库不少,为了方便起见,我们就使用sqlite3吧,方便到什么程度呢,因为python3已经内置了sqlite3,所以我们什么都不用做就可以拿来用。
django要求我们把需要使用到的数据做成模型,然后它再根据这些模型跟数据库打交道,所以,我们只要制作模型就可以了,那什么是模型呢,我们打开myCloud目录下的models.py文件,把我们的文件数据模型放进去。
from django.db import models
# Create your models here.
class fileModel(models.Model):
myfile = models.FileField(upload_to='upload')
upload_date = models.DateField(auto_now_add=True)
以上就是数据模型了。
怎么去理解上面的代码呢,我们看到,我们新建了一个class,这个类名是
fileModel这也就是我们需要的数据表格的名字,我们创建的这个类就相当于告诉django,你给我在数据库里新建一个叫fileModel的Excel表格。
然后这个表格就只有三栏,其中一栏是默认的,不需要我们手动增加,数据库会对每一行新加入的数据进行编号,俗称id号(实际上Excel每一行也都有标号,你可以把这一栏看作是默认栏目),每次有新数据进来就会自动编号。而另两栏,就是我们写的两行代码。
第一行是myfile 表示这一栏(或者说这一列)里面存的是一种叫文件的数据类型,根据这个数据类型,我们能够直接得到文件名和文件所在的路径,excel只能存字符串,或者说你只能往里面打字,但是django的一小格我们能里面填文件。
第二行uplaod_date表示这一栏存的是一种叫日期的数据类型,我们把auto_now_add设置为True表示说这里记录文件上传时的日期。
django是不是很人性化,啥都给你弄得妥妥的!
数据模型就是这么简单,其实是我们给数据库创建表格做了一个模板,数据库会创建这么一个类似excel的表单
之后,我们往里面填数据的时候就会变成这样:
我们可以从中取出文件1,然后获得该文件的路径和文件名,比如‘huluwa.avi’和他所在的路径,比如'myCloud/upload/huluwa.avi'
而我们看到之前的函数,里面有一条叫‘upload_to’的参数,他就是要我们指明文件的上传路径。因为,数据库不会真的把这个文件都放进去,记录的是文件的信息,而真正的文件则传到上传路径里面。(不过,我们可以假装文件真的是放进数据库里面的一个个小格子里面去了)
设计好数据模型后,我们需要运行
python manage.py makemigrations
python mange.py migrate
做好数据库的启动,这时数据库会根据模型创建好上面提到的表单,这时表单当然是空的,我们需要制作上传的功能,也就是把数据存进数据库。