Django入门指导
1,安装python包管理工具pip
在ubuntu环境下,我们通常apt-get来安装软件,当时pip是专门用来管理python包的工具,相对apt-get来说,安装与python有关的包更加方便,能够精确控制安装软件的版本,同时,当我们直接拿到别人的django工程时,如果有一些依赖的包,能够很快的使用pip解决依赖关系,pip之于python,npm之于node.js。
安装pip工具
sudo apt-get install python-pip
2,安装django
通过第一步中pip工具,来安装django,有时我们下指定安装某个版本
sudo pip install Django==1.7.1
当然也可以直接通过apt-get来安装django
sudo apt-get install Django (不推荐)
当然也可以通过源码安装(耗时耗力,不推荐)
python命令行下检验是否安装成功
>>> import django
>>> django.VERSION
(1, 7, 1, 'final', 0)
3,新建django工程
django-admin startproject website 或者
django-admin.py startproject website
通过Linux源码安装或者pip安装django时,django-admin有可能用不了,推荐用django-admin.py
执行完上述命令,会在当前目录新建website工程,目录结构如下
fage:Server$ tree website
website
├── manage.py
└── website
├── __init__.py
├── settings.py
├── urls.py
└── wsgi.py
1 directory, 5 files
新建一个website目录,还有website子目录,还有四个py文件
manage.py: ---------Django项目里面的命令行工具,用于跟项目的各种交互,通过它可以调用django shell和数据库
init.py: -------一个空文件让Python知道这个目录是一个Python包
settings.py -------- 包含了项目的默认设置,包括数据库信息,调试标志,时区,静态文件目录
urls.py ----- 负责把URL模式映射到应用程序,建立网址和视图函数之间的对应关系
wsgi.py ----- 负责和Nginx或者Apache交互用的,当使用django自带的web服务器时不用理会。
manage.py文件,我们会经常用到,但是我们基本不会改里面的内容,只是用来启动web服务,同步数据库等等
init.py基本不用关注
settings.py文件是我们经常需要修改的文件
urls.py也是我们经常需要修改的文件
wsgi.py当你把django部署在生产环境,用django自带的web服务器就不是很合适,这个时候我们需要部署Nginx或者Apache,此时需要设置wsgi.py
4,新建app
python manage.py startapp blog
fage:website$ tree
.
├── blog
│ ├── admin.py
│ ├── __init__.py
│ ├── migrations
│ │ └── __init__.py
│ ├── models.py
│ ├── tests.py
│ └── views.py
├── manage.py
└── website
├── __init__.py
├── __init__.pyc
├── settings.py
├── settings.pyc
├── urls.py
└── wsgi.py
5,修改settings.py
添加app到 settings.py
INSTALLED_APPS = (
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'blog',
)
设置语言和时区
LANGUAGE_CODE = 'zh-CN'
TIME_ZONE = 'Asia/Shanghai'
- zh-CN是为了django能够显示中文
- Asia/Shanghai是将时区设置为本地时区
6,修改urls.py
设置urls.py有两种方式
- 6.1直接在website的urls.py中设置
from django.conf.urls import patterns, include, url
from django.contrib import admin
urlpatterns = patterns('',
# Examples:
# url(r'^$', 'my0813.views.home', name='home'),
# url(r'^blog/', include('blog.urls')),
url(r'^admin/', include(admin.site.urls)),
url(r'^blog/$', 'blog.views.blog_index', name='blog_index'),
)
- 6.2通过website的urls.py和blog应用中的urls.py
设置website的urls.py
from django.conf.urls import patterns, include, url
from django.contrib import admin
urlpatterns = patterns('',
# Examples:
# url(r'^$', 'my0813_01.views.home', name='home'),
# url(r'^blog/', include('blog.urls')),
url(r'^admin/', include(admin.site.urls)),
url(r'^blog/', include('blog.urls')),#blog.urls的''不能省略
)
在blog目录新建urls.py,编辑urls.py
from django.conf.urls import patterns, url
urlpatterns = patterns('',
# Examples:
# url(r'^$', 'my0813_02.views.home', name='home'),
# url(r'^blog/', include('blog.urls')),
url(r'^$', 'blog.views.blog_index'),#$符号之后不要加/
)
- 6.3urls.py的详细请参考
urls.py详解
7,编辑视图文件
编辑blog目录下的views.py文件
from django.shortcuts import render
from django.http import HttpResponse
# Create your views here.i
def blog_index(request):
return HttpResponse("Hello, world.")
8,运行web服务
因为没有设置从html文件中获取数据, 就没有设置Templates目录和static目录,只是为了简单地显示一个hello world
- 8.1本地运行
只能在本机访问
python manage.py runserver 8000
- 8.2远端访问
python manage.py runserver 0.0.0.0:8000