ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
[TOC] ## **一、 新建项目** **PS:** 这一小结,并不一定需要在命令行下操作,我们可以在Pycharm环境下进行,并且同时创建虚拟环境。参考上节内容。 进入你期望的项目保存目录,运行下面的命令: ~~~ $ django-admin startproject mysite ~~~ 这将在目录下生成一个mysite目录,也就是你的这个Django项目的根目录。它包含了一系列自动生成的目录和文件,具备各自专有的用途。 注意:在给项目命名的时候必须避开Django和Python的保留关键字,比如“django”,“test”等,否则会引起冲突和莫名的错误。对于mysite的放置位置,不建议放在传统的/var/wwww目录下,它会具有一定的数据暴露危险,因此Django建议你将项目文件放在例如/home/mycode类似的位置。 一个新建立的项目结构大概如下: ~~~ mysite/ manage.py mysite/ __init__.py settings.py urls.py asgi.py wsgi.py ~~~ 各文件和目录解释: * 外层的`mysite/`目录与Django无关,只是你项目的容器,可以任意重命名。 * `manage.py`:一个命令行工具,管理Django的交互脚本。 * 内层的`mysite/`目录是真正的项目文件包裹目录,它的名字是你引用内部文件的Python包名,例如:`mysite.urls`。 * `mysite/__init__.py`:一个定义包的空文件。 * `mysite/settings.py`:项目的配置文件。 * `mysite/urls.py`:路由文件,所有的任务都是从这里开始分配,相当于Django驱动站点的目录。 * `mysite/wsgi.py`:一个基于WSGI的web服务器进入点,提供底层的网络通信功能,通常不用关心。 * `mysite/asgi.py`:一个基于ASGI的web服务器进入点,提供异步的网络通信功能,通常不用关心。 <br /> ## **二、 启动开发服务器** 回到mysite项目的根目录,也就是`manage.py`文件的同级目录下,输入下面的命令: ~~~ $ python3 manage.py runserver ~~~ 你会看到下面的提示,这表明Django的开发服务器已经启动,开始提供Web服务了: ~~~ Performing system checks... System check identified no issues (0 silenced). You have 18 unapplied migration(s). Your project may not work properly until you apply the migrations for app(s): admin, auth, contenttypes, sessions. Run 'python manage.py migrate' to apply them. August 31, 2020 - 15:01:31 Django version 3.1, using settings 'mysite.settings' Starting development server at http://127.0.0.1:8000/ Quit the server with CTRL-BREAK. ~~~ **Django提供了一个用于开发的web服务器,使你无需配置一个类似Ngnix的生产服务器,就能让站点运行起来。**这是一个由Python编写的轻量级服务器,简易并且不安全,因此不要将它用于生产环境。 打开浏览器,访问`http://127.0.0.1:8000/`,你将看到Django的火箭欢迎界面,一切OK! Django的开发服务器(以后简称服务器)默认运行在内部的8000端口,如果你想指定端口,请在命令中显示给出: ~~~ $ python3 manage.py runserver 8080 ~~~ 如果想修改服务器的ip地址,请按下面的方式运行命令,比如: ~~~ $ python3 manage.py runserver 0:8000 ~~~ 0 是 0.0.0.0 的简写,Django将运行在0.0.0.0:8000上,整个局域网内都将可以访问站点,而不只是是本机(这其中可能还需要做一些配置和网络测试)。 注意:**Django的开发服务器具有自动重载功能,当你的Python代码有修改,服务器会在一个周期后自动更新。** 但是,有一些动作,比如增加文件,不会触发服务器重载,这时就需要你自己手动重启。所以建议,在任何修改代码的操作后,手动重启开发服务器,确保修改被应用。 PS: 重启服务器的操作在Pycharm里只需要简单地点击按钮即可。 ![](https://img.kancloud.cn/b6/a0/b6a0ca82d6fe07901171d8626d37b00b_921x571.png) <br /> ## **三、 创建投票应用(app)** 在 Django 中,每一个应用(app)都是一个 Python 包,并且遵循着相同的约定。Django 自带一个工具,可以帮你生成应用的基础目录结构。 app应用与project项目的区别: * 一个app实现某个具体功能,比如博客、公共档案数据库或者简单的投票系统; * 一个project是配置文件和多个app的集合,这些app组合成整个站点; * 一个project可以包含多个app; * 一个app可以属于多个project! app的存放位置可以是任何地点,但是通常都将它们放在与`manage.py`脚本同级的目录下,这样方便导入文件。 进入mysite项目根目录,确保与`manage.py`文件处于同一级,输入下述命令: `$ python3 manage.py startapp polls` 系统会自动生成 polls应用的目录,其结构如下: ~~~ polls/ __init__.py admin.py apps.py migrations/ __init__.py models.py tests.py views.py ~~~ 在Pycharm中,没有可以创建app的图形化按钮,需要在下方的`Terminal`终端中输入命令: ~~~ python3 manage.py startapp polls ~~~ 这样也能创建polls应用。 ![](https://img.kancloud.cn/59/5e/595e8a0ae43cfc15d352a02e6619f7b8_845x325.png) 通过前面在Pycharm中创建工程的方式有个方便之处,点击Terminal后,会自动进入虚拟环境。 <br /> ## **四、编写第一个视图** 下面,我们编写一个视图,也就是具体的业务代码。 在`polls/views.py`文件中,编写代码: ~~~ from django.http import HttpResponse def index(request): return HttpResponse("这里是liujiangblog.com的投票站点") ~~~ 为了调用该视图,我们还需要编写urlconf,也就是路由配置。在polls目录中新建一个文件,名字为`urls.py`(不要换成别的名字),在其中输入代码如下: ~~~ from django.urls import path from . import views urlpatterns = [ path('', views.index, name='index'), ] ~~~ 此时,目录的文件结构是这样的: ~~~ polls/ __init__.py admin.py apps.py migrations/ __init__.py models.py tests.py urls.py views.py ~~~ 我们先不用深究`urls.py`中代码的具体含义。 接下来,在项目的**主urls.py文件**中添加`urlpattern`条目,指向我们刚才建立的polls这个app独有的urls.py文件,这里需要导入include模块。打开`mysite/urls.py`文件,代码如下: ~~~ from django.contrib import admin from django.urls import include, path urlpatterns = [ path('polls/', include('polls.urls')), path('admin/', admin.site.urls), ] ~~~ include语法相当于多级路由,它把接收到的url地址去除与此项匹配的部分,将剩下的字符串传递给下一级路由urlconf进行判断。在路由的章节,有更加详细的用法指导。 <br /> include的背后是一种即插即用的思想。项目的根路由不关心具体app的路由策略,只管往指定的二级路由转发,实现了应用解耦。app所属的二级路由可以根据自己的需要随意编写,不会和其它的app路由发生冲突。app目录可以放置在任何位置,而不用修改路由。这是软件设计里很常见的一种模式。 <br /> **建议**:除了admin路由外,尽量给每个app设计自己独立的二级路由。 <br /> 好了,路由设置成功后,启动服务器,然后在浏览器中访问地址`http://localhost:8000/polls/`。一切正常的话,你将看到`这里是liujiangblog.com的投票站点` <br /> ## **五、path()方法** 一个路由配置模块就是一个urlpatterns列表,列表的每个元素都是一项path,每一项path都是以path()的形式存在。 <br /> path()方法可以接收4个参数,其中前2个是必须的:`route`和`view`,以及2个可选的参数:`kwargs`和`name`。 以下面的代码为例: ~~~ from django.urls import path from . import views urlpatterns = [ path('', views.index, name='index'), ] ~~~ ### **route** route 是一个匹配 URL 的准则(类似正则表达式)。当 Django 响应一个请求时,它会从 urlpatterns 的第一项path开始,按顺序依次匹配列表中的项,直到找到匹配的项,然后执行该条目映射的视图函数或下级路由,其后的条目将不再继续匹配。因此,url路由执行的是短路机制,path的编写顺序非常重要! <br /> 例子中对应的route就是空字符串`''` <br /> 需要注意的是,route不会匹配 GET 和 POST 参数或域名。例如,URLconf 在处理请求`https://www.liujiangblog.com/myapp/`时,它会尝试匹配`myapp/`。处理请求`https://www.liujiangblog.com/myapp/?page=3`时,也只会尝试匹配`myapp/`。 <br /> ### **view** view指的是处理当前url请求的视图函数。当Django匹配到某个路由条目时,自动将封装的`HttpRequest`对象作为第一个参数,被“捕获”的参数以关键字参数的形式,传递给该条目指定的视图view。 例子中对应的view就是`views.index` <br /> ### **kwargs** 任意数量的关键字参数可以作为一个字典传递给目标视图。 本例中没有使用这个参数。 <br /> ### **name** 对你的URL进行命名,让你能够在Django的任意处,尤其是模板内显式地引用它。这是一个非常强大的功能,相当于给URL取了个全局变量名,不会将url匹配地址写死。 本例子中没有使用这个参数。 path()方法的四个参数,每个都非常有讲究,这里先做基本的介绍,在后面有详细的论述。