上一篇博文已经成功安装了python环境和Django,并且新建了一个空的项目.接下来就可以正式开始进行Django下
的Web开发了.首先进入项目的主目录:
`cd ./DjangoLearn/hollow_world`
新建一个app名字为'myBlog':
`python manage.py startapp myBlog`
新建完成之后,可以看到当前目录多了一个叫myBlog的文件目录.
.
1 注册app
接下来我们编辑'hollow_world'目录下的setting.py
文件.找到'INSTALLED_APPS'的这个list.在最后添加一行,注册我们新建的app:
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'myBlog',#在项目中注册myBlog这个app
进入myBlog目录会发现里面有两个文件目录和一些'.py'结尾的python文件.
2 function view
我们首先编辑一下'views.py'写一个方法,来实现让浏览器输出'Hollow world!':
from django.shortcuts import render
from django.http import HttpResponse#导入HttpResponse对象
# Create your views here.
def hollow_world(request):
if request.method=='GET':
return HttpResponse('Hollow world!')
else:
return HttpResponse('Hollow world fiale')
上面的代码实际上是定义了一个方法(function),功能是:当接收到一个HTTP请求时,先判断一下请求的方式是不是'GET',如果是,就返回一个用'Hollow world!'这个字符进行初始化的HttpResponse对象(在这里Hollow world会在浏览器访问时显示在页面上).Django官方把这种直接用def关键字定义方法来处理http请求的方式称为function view。
前面注册了app,也定义完了function是不是就可以了启动服务访问呢?并不是,我们还需要进行路由的映射才行.
3 urls.py
编辑'hollow_world'文件目录下的urls.py
文件:
from django.contrib import admin
from django.urls import path
from myBlog.views import hollow_world#引入上面编写的hollow_world()方法
urlpatterns = [
path('admin/', admin.site.urls),
path('',hollow_world),#将路由映射到hollow_world()这个function上
]
到这里可以说是万事具备,只欠东风了.在我们的项目文件目录下启动服务:python manage.py runserver 8080
服务正常启动如下图:
.
在浏览器中输入:127.0.0.1:8080
进行访问,就能看到'Hollow world! '了!
到这里可以算是完成了一次:
用户访问浏览器-->浏览器收到用户请求并且响应-->浏览器渲染服务器的响应
的一个完整过程.
现在概括一下django web的 一般步骤:
第一步:用`django-admin startproject`命令创建项目。
第二步: 用`python manager.py startapp`创建app。
第三步: 在项目的`setting.py` 文件里注册app
第四步: 在app文件目录下的`view.py`里编写视图函数.
第五步:修改项目文件的`urls.py`文件,进行路由映射,然后就可以启动服务访问了!
4 class-based view
上文中编写views.py
里的视图函数用的是function view的方式先判断http请求的方式然后再做对应的处理,在业务逻辑较复杂时代码可读性不是很好。在实际开发中,为了避免频繁的判断http请求方式,和提高代码的可读性,一般采用class-based view 的方式来处理http请求。关于class-based view的介绍请看Django官方文档.
用class-based view 的方式来实现让浏览器输出'Hollow world!',views.py
的代码如下:
from django.shortcuts import render
from django.views import View #导入View这个基础类
from django.http import HttpResponse
# Create your views here.
class HollowView(View):
"""docstring for HollowView."""
def get(self,request):
return HttpResponse('Hollow world!')
要使用class-based view 必须要:
from django.views import View #导入View这个基础类
所有自定义的视图类(在这个例子中是HollowView)必须是View的子类。也就是说,我们在定义自己的视图类的时候,必须继承View这个类。
上面我们修改了views.py
,接下来是修改项目文件目录下的urls.py
:
from django.contrib import admin
from django.urls import path
from myBlog.views import HollowView#导入HollowView
urlpatterns = [
path('admin/', admin.site.urls),
path('',HollowView.as_view()),
]
在使用HollowView这个视图类之前必须先导入:
from myBlog.views import HollowView#导入HollowView
这里的HollowView.as_view()
调用了HollowView的as_view()
方法是因为Django的路由是把http请求映射到一个可调用的方法上,而HollowView是一个视图类,不是可调用的方法。as_view()
是视图类的一个class function,作用是创建一个视图类的实例,并且调用该实例的dispatch()
方法,dispatch()
方法会根据传入的http的请求方式去匹配对应的方法进行请求的处理(在HollowView中我们只定义了用于处理http请求方式为GET的处理方法)。
5 urls.py 使用include()
在开发中,一个Django项目下可能不止一个app,如果每定义一个视图类就都要修改项目文件的urls.py
难免会出错。实际上我们可以在每个app文件目录下新建一个urls.py
文件。django为我们提供了一个include()
方法,利用include()
方法,可以让项目文件目录的urls.py
包含app文件目录下的urls.py
,阅读项目文件的urls.py
的注释部分,你会发现官方也提倡我们这么做。就以当前项目作为例子,项目文件目录的urls.py
内容为:
from django.contrib import admin
from django.urls import path,include
# from myBlog.views import HollowView
urlpatterns = [
path('admin/', admin.site.urls),
path('blog/',include('myBlog.urls')),#当请求的url是以‘blog/’开头时,则去Blog这个app下的`urls.py`进行匹配。
]
myBlog 文件目录下的的urls.py
内容为:
from django.contrib import admin
from django.urls import path
from myBlog.views import HollowView
urlpatterns=[
path('',HollowView.as_view()),
]
执行python manage.py runserver
服务启动后,我们访问127.0.0.1:8000/blog
就可以看到页面上输出了‘Hollow world!’
最后我们来概括一下Django 的Web开发的一般步骤:
第一步:用`django-admin startproject`命令创建项目。
第二步: 用`python manager.py startapp`创建app。
第三步: 在项目的`setting.py` 文件里注册app
第四步: 在app文件目录下的`view.py`里编写视图函数(实际开发中尽量使用class-based view).
第五步:在app文件目录下新建一个`urls.py`文件,并且修改项目文件的`urls.py`文件,进行路由映射(推荐使用项目目录`urls.py`中使用`include()`方法指向app中`urls.py`的方式)
下一篇文章内容是关于django form的构造,使用以及template的使用