用django搭建一个简单到不好意思见人的博客
首先安装django,最简单的方法是用pip安装
pip install Django==1.8.2
因为中文帮助文档是这个版本。。咳咳
话不多说,首先新建第一个django项目
django-admin startproject myblog
接着创建一个应用
cd myblog
python manage.py startapp article
然后做一些初步的设置。
进入myblog/myblog/settings.py
TEMPLATES=[{'BACKEND':'django.template.backends.django.DjangoTemplates','DIRS':[os.path.join(BASE_DIR,'templates')],'APP_DIRS':True,'OPTIONS':{'context_processors':['django.template.context_processors.debug','django.template.context_processors.request','django.contrib.auth.context_processors.auth','django.contrib.messages.context_processors.messages',],},},]
添加
'DIRS':[os.path.join(BASE_DIR,'templates')],
顺便把我们 新创建的应用加入到应用列表中
INSTALLED_APPS=('django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles','article',)
写我们的第一个models
fromdjango.dbimportmodelsclassArticle(models.Model):title=models.CharField(max_length=100)create_time=models.DateTimeField(auto_now_add=True)content=models.TextField()
然后我们迁移数据库
在项目目录下,即有manage.py的目录
python manage.py makemigrations
第一句会更加你models的改变创建迁移脚本
python manage.py migrate
第二句就是迁移
这个models有个小问题,后面遇到了我会说~
下面我们要增加一个主页。有两种方式一种是基于函数视图,一种是基于类的视图,最开始我们就用就基础的基于函数的视图(实话是基于类的还不怎么会,咳咳。。其实基于函数的也不怎么会。。慢慢学呗)
因为我们要做的尽量简单所以就只建一个显示文章列表的主页
fromdjango.shortcutsimportrenderfrom.modelsimportArticledefindex(request):article_list=Article.objects.all()returnrender(request,'article/index.html',{'article_list':article_list})
我们先从数据库的Article表中取出所有的所有数据赋值给article_list在通过render函数传递给我们的模板文件index.html
接下来就时建我们的模板文件了。首先在应用的目录下就时myblog/article/目录下新建一个目录templates然后在这个目录中再建一个目录article,再在这个目录中建一个index.html。现在我们的项目目录树如下:
myblog/├──article│├──admin.py│├──__init__.py│├──migrations││├──0001_initial.py││├──__init__.py│├──models.py│├──templates││└──article││└──index.html│├──tests.py│├──views.py├──db.sqlite3├──manage.py└──myblog├──__init__.py├──settings.py├──urls.py├──wsgi.py
为什么django能找到我们的html.index文件呢?就是因为我们之前在setting.py设置了templates:
'DIRS':[os.path.join(BASE_DIR,'templates')],
然后我为我们的主页index.html增加一些简单的html标签
<!doctypehtml><htmllang="en"><head><metacharset="UTF-8"><title>Document</title></head><body><div>{%forarticleinarticle_list%}<h2><ahref="#">{{article.title}}</a></h2><p>Time:{{article.create_time}}</p><p>{{article.content}}</p>{%endfor%}</div></body></html>
我们还得自己定义个url来指向我们所创建的视图。
因为时简单的博客 我们就直接在
myblog/myblog/urls.py中添加我们的url
fromdjango.conf.urlsimportinclude,urlfromdjango.contribimportadminfromarticle.viewsimportindexurlpatterns=[url(r'^admin/',include(admin.site.urls)),url(r'^$',index,name='index')]
现在整个简单的博客就搭建完成了,当然这其中还有一些问题还得解决。
我们项目的主目录下就是有manage.py的目录下运行
pythonmanage.purunserver
然后我们就可以访问我们的博客了,输入http://127.0.0.1:8000/
当然我们博客里面还没有文章,因为我们这个博客没有添加文章的页面,所以我们要用到django帮我自动生成的后台。
还是,在我们项目的主目录下就是有manage.py的目录下运行
pythonmanage.pycreatesurperuser
输入账号密码,新建一个后台管理账号
然后我们在浏览器中输入http://127.0.0.1:8000/admin/访问我们的后台,不过我们发现并没有我们的Article条目提供给我们编辑。解决方法如下
在我们的应用目录中有一个admin.py文件,即myblog/article/admin.py添加代码如下:
fromdjango.contribimportadminfrom.modelsimportArticleadmin.site.register(Article)
在线我们在访问http://127.0.0.1:8000/admin/我们就可以添加文章了,当然。。。。还是有问题。。。我们点add article 增加文章后,文章列表显示的时Article object这肯定不是我们所想要 的,我们想要的是它可以显示我们文章的title
解决方法如下:
在myblog/article/models.py中,我们自己创建的Article中添加代码如下
fromdjango.dbimportmodelsclassArticle(models.Model):title=models.CharField(max_length=100)create_time=models.DateTimeField(auto_now_add=True)content=models.TextField()def__unicode__(self):returnself.title
如果还有什么问题就是我写这篇文章的时候遗漏了。。。。可私信我哇咔咔。不过一般不怎么看博客。。。。能不能看到就看你的运气了~~
路人甲:这也敢叫博客!!!!
博主: 咳咳,好尴尬~
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。