Django是用python写的web框架。
1. 安装简单:
pip install django
验证:
python -m django --version
或者:
import django
print(django.get_version())
2. 创建Django项目:假设项目名为mysite,需要先切换到要目标目录下再创建
django-admin startproject mysite
该步骤将创建以下文件:
mysite/ 根目录只是你项目的容器, Django 不关心它的名字,你可以将它重命名为任何你喜欢的名字。 manage.py 管理 Django 项目的命令行工具 mysite/ 项目名,它是一个纯 Python 包。当你引用它内部任何东西时需要用到的 Python 包名,比如 mysite.urls __init__.py 一个空文件,告诉 Python 这个目录应该被认为是一个 Python 包 settings.py Django 项目的配置文件 urls.py Django 项目的 URL 声明,就像你网站的“目录” wsgi.py 作为你的项目的运行在 WSGI 兼容的Web服务器上的入口
验证项目是否创建成功:
如果你的当前目录不是外层的 mysite
目录的话,请切换到此目录,然后运行下面的命令:
python manage.py runserver
看提示,成功后有一个网址,可以访问,一般为http://127.0.0.1:8000,也就是localhost:8000。
更换服务器的监听端口:
python manage.py runserver 8080
修改服务器监听的IP,在端口之前输入新的:0 是 0.0.0.0 的简写
python manage.py runserver 0:8000
3. 创建应用:在 Django 中,每一个应用都是一个 Python 包。
项目和应用有啥区别?应用是一个专门做某件事的网络应用程序——比如博客系统,或者公共记录的数据库,或者简单的投票程序。项目则是一个网站使用的配置和应用的集合。项目可以包含很多个应用。应用可以被很多个项目使用。
创建应用:python manage.py startapp polls
创建的polls应用目录如下:
polls/ 应用名,一个python包 __init__.py 一个空文件,告诉 Python 这个目录应该被认为是一个 Python 包 admin.py apps.py migrations/ __init__.py models.py tests.py views.py 视图 urls.py 新建
一个简单的响应:
#polls/views.py文件
from django.http import HttpResponse
def index(request):
return HttpResponse("Hello, world. You're at the polls index.")
为了创建 URLconf,请在 polls 目录里新建一个 urls.py
文件
#polls/urls.py
from django.urls import path
from . import views
urlpatterns = [
path('', views.index, name='index'),
]
在根 URLconf 文件中指定我们创建的 polls.urls
模块:
# 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()
允许引用其它 URLconfs。每当 Django 遇到 :func:~django.urls.include 时,它会截断与此项匹配的 URL 的部分,并将剩余的字符串发送到 URLconf 以供进一步处理。
我们设计 include()
的理念是使其可以即插即用。因为投票应用有它自己的 URLconf( polls/urls.py
),他们能够被放在 "/polls/" , "/fun_polls/" ,"/content/polls/",或者其他任何路径下,这个应用都能够正常工作。
函数 path()
具有四个参数,两个必须参数:route
和 view
,两个可选参数:kwargs
和 name
。
参数 route
:是一个匹配 URL 的准则(类似正则表达式)。当 Django 响应一个请求时,它会从 urlpatterns
的第一项开始,按顺序依次匹配列表中的项,直到找到匹配的项。
这些准则不会匹配 GET 和 POST 参数或域名。例如,URLconf 在处理请求 https://www.example.com/myapp/
时,它会尝试匹配 myapp/
。处理请求 https://www.example.com/myapp/?page=3
时,也只会尝试匹配 myapp/
。
参数 view: 当 Django 找到了一个匹配的准则,就会调用这个特定的视图函数,并传入一个 HttpRequest
对象作为第一个参数,被“捕获”的参数以关键字参数的形式传入。稍后,我们会给出一个例子。
参数 kwargs: 任意个关键字参数可以作为一个字典传递给目标视图函数。本教程中不会使用这一特性。
参数 name: 为你的 URL 取名能使你在 Django 的任意地方唯一地引用它,尤其是在模板中。这个有用的特性允许你只改一个文件就能全局地修改某个 URL 模式。
验证是否正常工作:
python manage.py runserver