首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

基于Python搭建Django后台管理系统

一个好的项目数据库管理后台是必须的,今天代码君教大家搭建Django网站后台,当然做网站后台的前提是需要有Python以及Django的开发环境,至于如何搭建这些开发环境,请查看我的上一篇文章Mac 基于Python搭建Django应用框架,这篇文章的讲解是基于上一篇的,好了,开始进入正题

在上一篇文章中我们讲解了如何创建一个网站项目,今天代码君以搭建一个个人博客网站作为例子讲解网站后台的搭建

一、博客网站的创建

创建项目

生成站点(sites)Model,这两步骤第一篇有介绍,这里就直接操作了

二、数据库配置

介绍一下数据库的配置就是在setting里面配置链接的数据库,这里系统以及配置好了,链接一个叫做db.sqlite3的数据库,也许有读者会问,这个数据库在哪里,我怎么没有,没关系,你跑一下项目,系统就自动生成一个这个数据库了,当然django也支持MySQL等其他数据库,这里为了方便讲解,就用系统自带的

INSTALLED_APPS 这个参数是安装myBlog这个项目中所有用到的Application,当然我们创建的sites也是一个Application,所有也加进去,下面这几个都是系统自带的框架,默认安装

添加完sites到INSTALLED_APPS后需要执行下面终端命令, migrate会查看INSTALLED_APPS的设置,并根据myBlog/settings.py文件中的数据库设置创建任何必要的数据库表

终端命令:python manage.py migrate

之后,我们运行一下项目,输入http://127.0.0.1:8000/admin看一下效果

三、数据库后台搭建

到登录页基本完成一半啦,接下来就需要创建一个管理员账户用于登录使用,

终端命令:python manage.py createsuperuser

创建完账户就可以去登录了,效果如下

因为全部是英文,代码君看不惯,想把他改成中文settings.py中将LANGUAGE_CODE 中的'en-us' 改成 'zh-Hans',这样看起来是不是舒服多了

四、创建数据库模型

在sites中的models创建数据库表的模型,如下图,字段有title、url、body、create_date

五、激活模型

这步很关键,你每次修改model里面的数据,都要从复执行这下面这几个步骤:

在 myBolg/settings.py 中,修改INSTALLED_APPS,引入要用到的Application,我们目前只有一个sites,已经引用过了,所以无需再引用

执行终端命令:

python manage.py makemigrations

python manage.py migrate

将model添加到sites/admin.py里

运行一下项目,打开管理界面,查看效果,然后你就看随意添加Article内容啦http://127.0.0.1:8000/admin

六、踩坑总结

UnicodeEncodeError: 'ascii' codec can't encode characters

之前模型model中写了一个方法 defstr(self):这个是旧版本中用的方法,Django新版本要换成defunicode(self):, 这样就解决了字符串传递时出错的问题,统一编码为Unicode字符串。

OperationalError no such table / OperationalError table sites_article has no column named test

这是一类错误,就是我之前提醒的,我们增加model或者修改models.py里面的代码后,需要从新执行步骤五,步骤五的作用就是更新数据库表的信息,比如你新增model中的一个字段,没有更新数据库表,自然会报上面的错误

解决方法:运行步骤五的终端命令

python manage.py makemigrations

python manage.py migrate

总结

今天代码君教了大家网站后台的搭建,可能你看完文章会觉得很容易,那是因为代码君已经帮你都踩完坑了,我在写教程之前,也参考了很多文章,大多数写的思路都不是很清晰,正因为如此,代码君才打算写这篇教程指引读者,原创不易,请觉得有用的读者为代码君点个赞哈~

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180104G0RMNR00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券