用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

from django.db import models
class Article(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有个小问题,后面遇到了我会说~

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

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

from django.shortcuts import render
from .models import Articledef
 index(request):
    article_list = Article.objects.all()
    return render(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

为什么django能找到我们的html.index文件呢?就是因为我们之前在setting.py设置了templates:
DIRS': [os.path.join(BASE_DIR, 'templates')],
然后我为我们的主页index.html增加一些简单的html标签

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
<div>
    {% for article in article_list %}
        <h1><a href="#">{{ article.title }}</a></h1>
        <p>        Time: {{ article.create_time }}        </p>
        <p>        {{ article.content }}        </p>
    {% endfor %}
</div>
</body>
</html>

我们还得自己定义个url来指向我们所创建的视图。
因为时简单的博客 我们就直接在
myblog/myblog/urls.py中添加我们的url

from django.conf.urls import include, url
from django.contrib import admin
from article.views import index
urlpatterns = [
    url(r'^admin/', include(admin.site.urls)),
    url(r'^$', index, name='index')
]

现在整个简单的博客就搭建完成了,当然这其中还有一些问题还得解决。
我们项目的主目录下就是有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添加代码如下:

from django.contrib import admin
from .models import Article  #导入我们自定义的models

admin.site.register(Article)  #把Aritcle注册到后台管理平台上

在线我们在访问http://127.0.0.1:8000/admin/我们就可以添加文章了,当然。。。。还是有问题。。。我们点add article 增加文章后,文章列表显示的时Article object这肯定不是我们所想要 的,我们想要的是它可以显示我们文章的title
解决方法如下:
在myblog/article/models.py中,我们自己创建的Article中添加代码如下:

from django.db import models
class Article(models.Model):
    title = models.CharField(max_length=100)
    create_time = models.DateTimeField(auto_now_add=True)
    content = models.TextField()
    def __unicode__(self):
        return self.title   #因为博主的python是2.x得用这个,如果时3.x就用def __str__(self)

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容