1. 创建项目——在当前路径下创建了一个mysite目录
django-admin startproject mysite
2. 目录结构
|-- mysite
| |-- __init__.py
| |-- settings.py
| |-- urls.py
| `-- wsgi.py
`-- manage.py
-
外部
mysite/
根目录:项目的容器。 - manage.py:一个实用的命令行工具,可让你以各种方式与该 Django 项目进行交互。
- mysite/init.py:一个空文件,告诉 Python 该目录是一个 Python 包。
- mysite/settings.py:该 Django 项目的设置/配置。
- mysite/urls.py:该 Django 项目的 URL 声明; 一份由 Django 驱动的网站"目录"。
- mysite/wsgi.py:一个 WSGI 兼容的 Web 服务器的入口,以便运行你的项目。
3. 运行服务器
python manage.py runserver 0.0.0.0:8000
让其它电脑可连接到开发服务器,8000 为端口号。如果不说明,那么端口号默认为 8000。
在浏览器输入你服务器的ip及端口号,如果正常启动,输出结果如下:
命令行内应该也有如下输出,证明启动无误:
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.
January 11, 2019 - 15:50:53
Django version 2.1, using settings 'mysite.settings'
Starting development server at [http://127.0.0.1:8000/](http://127.0.0.1:8000/)
Quit the server with CONTROL-C.</pre>
- 不要在生产环境中使用此服务器。它仅用于开发时使用
- 默认情况下,该
runserver
命令在端口8000的内部IP上启动开发服务器,要改变端口直接跟在命令最后即可,python manage.py runserver 8080 - 如果要更改服务器的IP,请将其与端口一起传递,
python manage.py runserver 0:8000
4. 创建 APP
执行python manage.py命令式请确定与manage.py在同一路径下)
python manage.py startapp myapp
项目与应用程序的关系
应用程序主要是负责执行操作,实现功能,类似博客里面的评论,登陆等等,而项目是特定网站的配置和应用程序的集合。项目可以包含多个应用程序。一个应用程序可以在多个项目中。执行应用创建命令之后会在当前路径下建立如下目录
|-- mysite
| |-- __init__.py
| |-- settings.py
| |-- urls.py
| `-- wsgi.py
|-- myapp
| |-- __init__.py
| |-- admin.py
| |-- models.py
| |-- tests.py
| `-- views.py
`-- manage.py
5. 应用结构
i. 视图
这里从单词就能看出来作用,类似MVC里面的views,主要是与页面视图相关的逻辑代码,并返回数据给页面使用
from django.http import HttpResponse
def index(request):
return HttpResponse("Hello, world. You're at the polls index.")
- HttpResponse是系统http模块方法,可通过它直接返回字符串,返回页面更多的使用render函数
ii. URL映射
要调用视图,我们需要将其映射到URL
这里的映射配置一般写在urls.py里面,可以直接写在大项目目录下的urls.py里面,但是为了区分不同应用间的功能,我们往往会在每个应用中独立出一个urls.py配置文件(配置类似,可以直接复制过去更改相应path),在最外部项目下面的urls.py里面调用include方法配置即可
这里配置好应用的urls之后我们去项目配置中设置URLconfig指向,这里需要导入include方法,该
include()
函数允许引用其他URLconf。每当Django遇到时include()
,它都会删除与该点匹配的URL的任何部分,并将剩余的字符串发送到包含的URLconf以进行进一步处理。
urls里面关于path的设置涉及四个参数,两个必需: route和view,以及两个可选:kwargs,和name。
route: route(路由)是一个包含URL模式的字符串。访问时请求的路径,处理请求时,Django从第一个模式开始urlpatterns并沿着列表向下移动,将请求的URL与每个模式进行比较,直到找到匹配的模式。这里不会对请求方法(GET/POST)进行区分
view: 当Django找到匹配的模式时,它调用指定的视图函数,其中一个HttpRequest
对象作为第一个参数,并且路由中的任何“捕获”值作为关键字参数。相当于传递一个视图函数中的方法,我们稍后会给出一个例子。
kwargs: 任意关键字参数可以在字典中传递到目标视图。我们不打算在教程中使用Django的这个功能(目前用处不多)
name: 命名您的URL可以让您从Django的其他地方明确地引用它,特别是在模板中。此强大功能允许您在只触摸单个文件的同时对项目的URL模式进行全局更改。相当于是给你调用的视图函数起一个名字,之后在返回的模板页面里面方便调用
polls/的urls.py
from django.urls import path
from . import views
urlpatterns = [
path('', views.index, name='index'),
]
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),
]
至此我们已经完成了第一个Django项目的第一部分,可以执行服务器然后去页面看一下效果,应该就是你视图函数里面编写的字符串内容,记得安装创建的应用哦
- 应用创建并且编写好视图函数以及urls等配置时记得去settings里面安装应用,将应用名字添加进INSTALLED_APPS即可