建立Django第一个项目

1、 新建项目

进入你指定的项目保存目录,而后运行下面的命令:python

$ django-admin startproject mysite

这将在目录下生成一个mysite目录,也就是你的这个Django项目的根目录。它包含了一系列自动生成的目录和文件,具有各自专有的用途。web

注意:在给项目命名的时候必须避开Django和Python的保留关键字,好比“django”,“test”等,不然会引发冲突和莫名的错误。对于mysite的放置位置,不建议放在传统的/var/www目录下,它会具备必定的数据暴露危险,所以Django建议你将项目文件放在例如/home/mycode相似的位置。正则表达式

一个新创建的项目结构大概以下:数据库

mysite/
    manage.py
    mysite/
        __init__.py
        settings.py
        urls.py
        wsgi.py

各文件和目录解释:django

  • 外层的mysite/目录与Django无关,只是你项目的容器,能够任意命名。浏览器

  • manage.py:一个命令行工具,用于与Django进行不一样方式的交互脚本,很是重要!安全

  • 内层的mysite/目录是真正的项目文件包裹目录,它的名字是你引用内部文件的包名,例如:mysite.urls服务器

  • mysite/__init__.py:一个定义包的空文件。网络

  • mysite/settings.py:项目的主配置文件,很是重要!app

  • mysite/urls.py:路由文件,全部的任务都是从这里开始分配,至关于Django驱动站点的内容表格,很是重要!

  • mysite/wsgi.py:一个基于WSGI的web服务器进入点,提供底层的网络通讯功能,一般不用关心。

2、 启动开发服务器

进入mystie项目的根目录,输入下面的命令:

$ python manage.py runserver

你会看到下面的提示,这代表Django的开发服务器已经启动,开始提供Web服务了:

Performing system checks...
System check identified no issues (0 silenced).
You have unapplied migrations; your app may not work properly until they are applied.
Run `python manage.py migrate' to apply them.
September 10, 2017 - 15:50:53
Django version 1.10, using settings `mysite.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CONTROL-C.

Django提供了一个用于开发的web服务器,使你无需配置一个相似Ngnix的线上服务器,就能让站点运行起来。这是一个由Python编写的轻量级服务器,简易而且不安全,所以不要将它用于生产环境。

修改配置文件,图以下:

image.png

打开浏览器,访问http://127.0.0.1:8000/,你将看到Django的欢迎界面,一切OK!

Django的开发服务器(之后简称服务器)默认运行在内部的8000端口,若是你想指定端口,请在命令中显示给出:

$ python manage.py runserver 8080

若是想修改服务器的ip地址,请按下面的方式运行命令:

$ python manage.py runserver 0.0.0.0:8000

这时,Django将运行在8000端口,整个局域网内都将能够访问站点,而不仅是是本机。

注意: Django的开发服务器具备自动重载功能,当你的代码有修改,每隔一段时间服务器将自动更新。可是,有一些例如增长文件的动做,不会触发服务器重载,这时就须要你本身手动重启。

3、 建立投票应用(app)

app应用与project项目的区别:

  • 一个app实现某个功能,好比博客、公共档案数据库或者简单的投票系统;

  • 一个project是配置文件和多个app的集合,这些app组合成整个站点;

  • 一个project能够包含多个app;

  • 一个app能够属于多个project!

app的存放位置能够是任何地点,可是一般都将它们放在与manage.py脚本同级的目录下,这样方便导入文件。

进入mysite项目根目录,确保与manage.py文件处于同一级,输入下述命令:

$ python manage.py startapp polls

系统会自动生成 polls应用的目录,其结构以下:

polls/
    __init__.py
    admin.py
    apps.py
    migrations/
        __init__.py
    models.py
    tests.py
    views.py

在Pycharm中,没有能够建立app的图形化按钮,须要在下方的terminal终端中输入命令:

python manage.py startapp polls

4、编写第一个视图

polls/views.py文件中,编写代码:

from django.http import HttpResponse
from django.conf.urls import include
def index(request):
    return HttpResponse("Hello, world. You're at the polls index.")

为了调用该视图,咱们还须要编写urlconf,也就是路由路径。如今,在polls目录中新建一个文件,名字为urls.py,在其中输入代码以下:

from django.conf.urls import url
from . import views
urlpatterns = [
    url(r'^$', views.index, name='index'),
]

此时,目录的文件结构是这样的:

polls/
    __init__.py
    admin.py
    apps.py
    migrations/
        __init__.py
    models.py
    tests.py
    urls.py
    views.py

接下来,在项目的主urls文件中添加urlpattern条目,指向咱们刚才创建的polls这个app独有的urls文件,这里须要导入include模块。打开mysite/urls.py文件,代码以下:

from django.conf.urls import include, url
from django.contrib import admin
from django.conf.urls import include
urlpatterns = [
    url(r'^polls/', include('polls.urls')),
    url(r'^admin/', admin.site.urls),
]

include语法至关于多级路由,它把接收到的url地址去除前面的正则表达式,将剩下的字符串传递给下一级路由进行判断。在路由的章节,有更加详细的用法指导。

include的背后是一种即插即用的思想。项目根路由不关心具体app的路由策略,只管往指定的二级路由转发,实现了应用解耦。app所属的二级路由能够根据本身的须要随意编写,不会和其它的app路由发生冲突。app目录能够放置在任何位置,而不用修改路由。这是软件设计里很常见的一种模式。

建议:除了admin路由外,尽可能给每一个app设计本身独立的二级路由。

好了,路由设置成功后,启动服务器,而后在浏览器中访问地址http://localhost:8000/polls/。一切正常的话,你将看到“Hello, world. You’re at the polls index.”

打开浏览器出现:

image.png

相关文章
相关标签/搜索