用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

1
TEMPLATES 
1
=

 

1
[

1
{

1
'BACKEND'
1
: 
1
'django.template.backends.django.DjangoTemplates'
1
,

1
'DIRS'
1
: [os.path.join(BASE_DIR, 
1
'templates'
1
)],

1
'APP_DIRS'
1
: 
1
True
1
,

1
'OPTIONS'
1
: {

1
'context_processors'
1
: [

1
'django.template.context_processors.debug'
1
,

1
'django.template.context_processors.request'
1
,

1
'django.contrib.auth.context_processors.auth'
1
,

1
'django.contrib.messages.context_processors.messages'
1
,

1
],

1
},

1
},

1
]

添加

DIRS': [os.path.join(BASE_DIR, 'templates')],

顺便把我们 新创建的应用加入到应用列表中

1
INSTALLED_APPS 
1
=

 

1
(

1
'django.contrib.admin'
1
,

1
'django.contrib.auth'
1
,

1
'django.contrib.contenttypes'
1
,

1
'django.contrib.sessions'
1
,

1
'django.contrib.messages'
1
,

1
'django.contrib.staticfiles'
1
,

1
'article'
1
,

1
)

写我们的第一个models

1
from

 

1
django.db 
1
import

 

1
models

1
class

 

1
Article(models.Model):

1
title 
1
=

 

1
models.CharField(max_length
1
=
1
100
1
)

1
create_time 
1
=

 

1
models.DateTimeField(auto_now_add
1
=
1
True
1
)

1
content 
1
=

 

1
models.TextField()

然后我们迁移数据库

在项目目录下,即有manage.py的目录

python manage.py makemigrations

第一句会更加你models的改变创建迁移脚本

python manage.py migrate

第二句就是迁移

这个models有个小问题,后面遇到了我会说~

下面我们要增加一个主页。有两种方式一种是基于函数视图,一种是基于类的视图,最开始我们就用就基础的基于函数的视图(实话是基于类的还不怎么会,咳咳。。其实基于函数的也不怎么会。。慢慢学呗)

因为我们要做的尽量简单所以就只建一个显示文章列表的主页

1
from

 

1
django.shortcuts 
1
import

 

1
render

1
from

 

1
.models 
1
import

 

1
Article

1
def

 

1
index(request):

1
article_list 
1
=

 

1
Article.objects.
1
all
1
()

1
return

 

1
render(request, 
1
'article/index.html'
1
, {
1
'article_list'
1
: article_list})

我们先从数据库的Article表中取出所有的所有数据赋值给article_list在通过render函数传递给我们的模板文件index.html

接下来就时建我们的模板文件了。首先在应用的目录下就时myblog/article/目录下新建一个目录templates然后在这个目录中再建一个目录article,再在这个目录中建一个index.html。现在我们的项目目录树如下:

            

1
myblog
1
/

            

1
├── article

            

1
│   ├── admin.py

            

1
│   ├── __init__.py

            

1
│   ├── migrations

            

1
│   │   ├── 
1
0001_initial
1
.py

            

1
│   │   ├── __init__.py

            

1
│   ├── models.py

            

1
│   ├── templates

            

1
│   │   └── article

            

1
│   │       └── index.html

            

1
│   ├── tests.py

            

1
│   ├── views.py

            

1
├── db.sqlite3

            

1
├── manage.py

            

1
└── myblog

            

1
├── __init__.py

            

1
├── settings.py

            

1
├── urls.py

            

1
├── wsgi.py

为什么django能找到我们的html.index文件呢?就是因为我们之前在setting.py设置了templates:

'DIRS': [os.path.join(BASE_DIR, 'templates')],

然后我为我们的主页index.html增加一些简单的html标签

1
<!doctype html>

1
<
1
html

 

1
lang
1
=
1
"en"
1
>

1
<
1
head
1
>

1
<
1
meta

 

1
charset
1
=
1
"UTF-8"
1
>

1
<
1
title
1
>Document</
1
title
1
>

1
</
1
head
1
>

1
<
1
body
1
>

1
<
1
div
1
>

1
{% for article in article_list %}

1
<
1
h1
1
><
1
a

 

1
href
1
=
1
"#"
1
>{{ article.title }}</
1
a
1
></
1
h1
1
>

1
<
1
p
1
>

1
Time: {{ article.create_time }}

1
</
1
p
1
>

1
<
1
p
1
>

1
{{ article.content}}

1
</
1
p
1
>

1
{% endfor %}

1
</
1
div
1
>

1
</
1
body
1
>

1
</
1
html
1
>


我们还得自己定义个url来指向我们所创建的视图。

因为时简单的博客 我们就直接在

myblog/myblog/urls.py中添加我们的url

1
from

 

1
django.conf.urls 
1
import

 

1
include, url

1
from

 

1
django.contrib 
1
import

 

1
admin

1
from

 

1
article.views 
1
import

 

1
index

1
urlpatterns 
1
=

 

1
[

1
url(r
1
'^admin/'
1
, include(admin.site.urls)),

1
url(r
1
'^$'
1
, index, name
1
=
1
'index'
1
)

1
]

现在整个简单的博客就搭建完成了,当然这其中还有一些问题还得解决。

我们项目的主目录下就是有manage.py的目录下运行

python manage.pu runserver

然后我们就可以访问我们的博客了,输入http://127.0.0.1:8000/

当然我们博客里面还没有文章,因为我们这个博客没有添加文章的页面,所以我们要用到django帮我自动生成的后台。

还是,在我们项目的主目录下就是有manage.py的目录下运行

python manage.py createsurperuser

输入账号密码,新建一个后台管理账号

然后我们在浏览器中输入http://127.0.0.1:8000/admin/访问我们的后台,不过我们发现并没有我们的Article条目提供给我们编辑。解决方法如下

在我们的应用目录中有一个admin.py文件,即myblog/article/admin.py添加代码如下:

1
from

 

1
django.contrib 
1
import

 

1
admin

1
from

 

1
.models 
1
import

 

1
Article

1
admin.site.register(Article)

在线我们在访问http://127.0.0.1:8000/admin/我们就可以添加文章了,当然。。。。还是有问题。。。我们点add article 增加文章后,文章列表显示的时Article object这肯定不是我们所想要 的,我们想要的是它可以显示我们文章的title

解决方法如下:

在myblog/article/models.py中,我们自己创建的Article中添加代码如下

1
from

 

1
django.db 
1
import

 

1
models

1
class

 

1
Article(models.Model):

1
title 
1
=

 

1
models.CharField(max_length
1
=
1
100
1
)

1
create_time 
1
=

 

1
models.DateTimeField(auto_now_add
1
=
1
True
1
)

1
content 
1
=

 

1
models.TextField()

1
def

 

1
__unicode__(
1
self
1
):

1
return

 

1
self
1
.title

如果还有什么问题就是我写这篇文章的时候遗漏了。。。。可私信我哇咔咔。不过一般不怎么看博客。。。。能不能看到就看你的运气了~~

 路人甲:这也敢叫博客!!!!

        博主: 咳咳,好尴尬~