Django框架1

  • 创建工程可以使用命令:django-admin startproject 工程名称
  • 当然也可以使用ide直接创建一个Django工程
  • 新建的工程可以直接运行python manage.py runserver来开启
  • Django同样是MVT模式,需要模型、路由视图和模板
  • 建好工程后如要新建一个子模块应用,可以使用命令:python manage.py startapp 子应用名称
  • 同样子应用的相关文件已经自动建好,但是需要手动添加一个urls.py文件用来写入路由
  • 创建好子应用后同样应该和Flask一样注册到主模块中去,这里将子应用下的apps.py里的UserConfig添加到主模块的settings.py里的INSTALLED_APPS列表里
  • 配置好后即可开始写路由和视图函数,这里视图函数在views.py内写入,需要注意的是该框架视图函数均需传入request对象:
from django.http import HttpResponse
def index(request):
    #这里的request对象为框架自动构造,但是response则需开发者构造
    return HttpResponse("hello the world!")
  • 然后在urls.py文件内写入路由,路由文件内是一个名为urlpatterns的列表,这里和Flask不同,不使用装饰器,而是将所有路由放入一个单独的文件中:
from django.conf.urls import url
from . import views
    #这里同样需要将视图函数导入
urlpatterns = [
    #这个匹配到的路径对应该视图函数
    url(r'^index/$', views.index),
]
  • 同时这里的路由也要注册到主模块的路由中,在主模块的urls.py文件的urlpatterns列表中写入路由:
from django.conf.urls import url, include
from django.contrib import admin
urlpatterns = [
    url(r'^admin/', admin.site.urls),  # django默认包含的
    # 添加子模块的路由,这里将包含子模块中的所有路由,所以该user模块的访问路径为协议://域名:端口/user/子模块下的具体地址,拿到url后首先匹配路径user/(这里自动忽略第一个/),匹配到后根据include找到子模块的urls,再根据子模块的路由去执行对应的视图函数,这也决定了user模块下的所有路由均以/user/开头,所以这里要访问index的完整路径为/user/index
    url(r'^user/', include('user.urls')), 
]
  • 配置文件settings.py
    • BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(_file_))) 定位当前工程的根目录
    • DEBUG
    • 语言:LANGUAGE_CODE = 'en-us' 这里可以改为中国中文:LANGUAGE_CODE = 'zh-hans'
    • 时区:TIME_ZONE = 'UTC' 这里同样可以更改:TIME_ZONE = 'Asia/Shanghai'
  • 请求路径及request携带参数提取:
    • 请求路径直接携带:如:http://xxxx:80/news/100 可以在路由中使用正则提取:url(r'^news/(\d{3})/$', views.news),将表达式用括号括起,此时再定义视图函数时则需要接收request对象和该匹配值,该值也可以取个名字:url(r'^news/(?P<id>\d{3})/$', views.news) 将?P<名字>放在前面即可
    • 获取请求路径中的查询字符串参数,如:http://xxxx:80/news/?id=100 这里直接使用request.GET.get('id')获取
    • 获取请求体中携带的表单参数,可以使用request.POST.get('id')获取
    • 获取请求体中非表单类型参数,如json,使用request.body获取,但是返回值为byte类型,需要转换,如json: json.loads(request.body.decode()).get(id)
    • 获取请求头的各种数据:如:request.META['CONTENT_TYPE']
  • 类视图
    • Django中可以以一个类来定义视图函数,这就是类视图
    • 使用类视图可以将视图对应的不同请求方式(如get,post)以类中的不同方法来区别定义
    • 并且类是可以继承的,这就有了更好的复用性
    • 类视图中定义的函数名只能是请求的小写,如get,post
from django.views.generic import View
class RegisterView(View):
#注册类,这里需要继承View,以在配置路由时使用as_view()方法
    def get(self, request):
        """处理GET请求,返回注册页面"""
        return render(request, 'register.html')
    def post(self, request):
        """处理POST请求,实现注册逻辑"""
        return HttpResponse('这里实现注册逻辑')
- 路由配置
urlpatterns = [
    # 视图函数:注册
    # url(r'^register/$', views.register),
    # 类视图:注册
    url(r'^register/$', views.RegisterView.as_view()),
]
  • 类视图装饰器
    • 使用method_decorator将装饰器直接定义在类上,传入自定义装饰器名和指明name(类视图中的方法名)即可
    • 在子模块下新建一个decorator.py文件,写入自定义装饰器,并在视图函数中导入
# 这里指明将装饰器dec_view给get函数使用,这里也可以将@method_decorator(dec_view)直接加到要装饰的方法上,如要给所有请求加此方法,则用name='dispatch'
@method_decorator(dec_view, name='get')
class register(View):
    def get(self,request):
        return HttpResponse('getRequest')
    def post(self,request):
        return HttpResponse('postRequest')
- 也可以将装饰器直接在路由文件中调用:
urlpatterns = [
    url(r'^register/$', dec_view(views.RegisterView.as_view())),
]
  • 中间件
    • 同Flask的钩子函数,在响应前或响应后执行
    • 定义中间件的形式同装饰器
    • 在子模块下新建一个middleware.py文件,写入中间件函数
def test_middleware(re_view):
    def middleware(request):
        print('响应前执行')
        # 这里时真正响应的视图函数
        response = re_view(request)
        print('响应后执行')
        return response
    return middleware
- 将函数注册到settings.py文件中的MIDDLEWARE列表中,这里是'user.middleware.test_middleware'
- 如有多个中间件执行顺序和一个函数上面加多个装饰器的顺序相同
posted @ 2019-03-08 23:47  heyeege  阅读(86)  评论(0编辑  收藏  举报