django路由分发+视图函数

目录

1、路由分发

1、1 传统的路由

1、2正则表达式路由

1、3路由分发

1、4name

1、5namespace

1、6 APPEND_SLASH

2、视图函数

2、1文件or文件夹

2、2视图函数中request对象

2、3返回值

2、4 响应头

2、5 响应体就是浏览器展示的内容

2、6 FBV和CBV


1、路由分发

1、1 传统的路由

from django.contrib import admin
from django.urls import path
from apps.web import views

urlpatterns = [
    path('home/', views.home),
    path('news//edit/', views.news),
    path('article/', views.article),
]
from django.shortcuts import render, HttpResponse


def home(request):
    return HttpResponse("成功")


def news(request, nid):
    print(nid)
    page = request.GET.get("page")
    return HttpResponse("新闻")


def article(request):
    nid = request.GET.get("nid")
    print(nid)
    return HttpResponse("文章")
  • int,整数

  • str,字符串

  • slug,字母+数字+下滑线+-

  • uuid,uuid格式

  • path,路径,可以包含 /

1、2正则表达式路由

django路由分发+视图函数_第1张图片

1、3路由分发

1、inlucde + app(一般),将功能拆分不到不同的app中。

# 很多功能,很多URL
urlpatterns = [
    path('api/', include('apps.api.urls')),
]

#在apps.api.urls中做二级分发
# 很多功能,很多URL
urlpatterns = [
    path('login/', account.login, name="login"),
    path('users/', account.UsersView.as_view(), name='aaaa'),
]

2、手动路由分发,可以与app无关。

path('user/add/', views.login),
path('user/delete/', views.login),
path('user/edit/', views.login),
path('user/list/', views.login),


path('user/', ([
                   path('add/', views.login),
                   path('delete/', views.login),   # /user/delete/
                   path('edit/', views.login),
                   path('list/', views.login),
               ], None, None)),

纯粹帮助提取功能的URL,防止重复编写。

3、路由分发的本质:

#URL对应函数:
path('user/add/', views.login),

#URL对应元组:
path('user/add/',    (元素,appname元素,namespance元素)    ),

path('user/add/',    include("apps.api.urls")    ),
path('user/add/',     ([],None,None)     ),

4、小结

  • include或手动元组列表,本质相同。

  • 应用场景和意义,想要把一些URL前缀提取出来。

  • path('user/add/', views.login),
    path('user/delete/', views.login),
    path('user/edit/', views.login),
    path('user/list/', views.login),
    
    
    path('user/', ([
                       path('add/', views.login),
                       path('delete/', views.login),   # /user/delete/
                       path('edit/', views.login),
                       path('list/', views.login),
                   ], None, None)),
                   
                   
    path('users', include(([
                               path('add/', views.login),
                               path('delete/', views.login),  # /user/delete/
                               path('edit/', views.login),
                               path('list/', views.login),
                           ], None))),
                           
    include("apps.api.urls")  # 一般是每个app中urls
    urlpatterns = [
    
    ]

1、4name

给一个路由起个名字 + 根据名字反向生成URL。

urlpatterns = [
    path('login/', views.login),
]


# 很多功能,很多URL
urlpatterns = [    path('login/', views.login, name="v1"),    
path('auth/', views.auth, name="v2"),
]

有了名字后,以后一般有两处会用到:

#1、在视图函数中生成URL
from django.urls import reverse
url = reverse("v2")   # /auth/
url = reverse("v1")   # /login/

#2、HTML模板,页面上有一个a标签,添加xx。
添加

添加
添加

#3、扩展
以后做权限管理,让name属性配合。

1、5namespace

避免由于路由分发,导致多个app中出现name同名情况无法通过name反向生成url时引入(namespace)

#1、主路由
from django.urls import path, re_path, include

# 很多功能,很多URL
urlpatterns = [
    path('api/', include("apps.api.urls",namespace='x1')),
    path('web/', include("apps.web.urls",namespace='x2')),
]

#2、api/urls.py文件

from django.urls import path, re_path
from . import views
# 很多功能,很多URL
urlpatterns = [
    path('login/', views.login,name="login"),
    path('auth/', views.auth, name='auth'),
]

#3、web/urls.py文件
from django.urls import path, re_path
from . import views
# 很多功能,很多URL
urlpatterns = [
    path('home/', views.home,name='home'),
    path('order/', views.order,name='order'),
    path('auth/', views.order, name='auth'),
]

#4、以后再某个URL或者视图中反向生成:
from django.urls import reverse
url = reverse("x1:login")    # /api/login/
url = reverse("x1:order")    # /web/login/

url = reverse("x1:auth")    # /api/login/
url = reverse("x2:auth")    # /web/login/

两个扩展:

#1、namespace需要设置app_name

urlpatterns = [    path('api/', include("apps.api.urls", namespace='x1')),]




#2、 很多功能,很多URL
from django.urls import path, re_path
from apps.api import views

# 很多功能,很多URL
urlpatterns = [
    path('login/', views.login, name="login"),
    path('auth/', views.auth, name='auth'),
]

app_name = "api"

1、6 APPEND_SLASH

APPEND_SLASH = True 访问url时,会自动补全url后面的/,

APPEND_SLASH = False时,访问url时,url是什么样式就访问什么url,不会自动补全url后面的/,

2、视图函数

2、1文件or文件夹

1、视图函数多时,在apps下创建一个views文件夹,在views文件夹下创建相应的视图函数

2、视图函数少时,直接在views.py文件下创建相应的视图函数

2、2视图函数中request对象

from django.shortcuts import HttpResponse


def login(request):
    # 1.当前URL  /api/login/
    print(request.path_info)

    # 2.URL传递的参数
    print(request.GET)
    print(request.GET.get("age"))

    # 3.请求方式  GET/POST
    print(request.method)

    # 4.如果post请求,传递请求体(原始数据)
    print(
        request.body)  # b'{"code":"083Sjmll2yla694F3bll2DguCM2SjmlG","unionId":"oP6QCsyT_9bk1dfSaVf0GEV5Y-yE"}'  b'v1=123&v2=456'

    # 4.1 请求体+请求头       b'v1=123&v2=456'  +  content-type:application/x-www-form-urlencoded
    print(request.POST)
    print(request.POST.get("v1"))
    print(request.POST.get("v2"))

    # 4.2 请求体+请求头   文件
    print(request.FILES)  # 文件格式           + multipart/form-data
    print(request.FILES.get("n1"))
    print(request.FILES.get("n2"))

    # 5.请求头
    print(request.headers)

    # 5.1 请求头有个特殊的cookie
    # request.headers['cookie']  # 'csrftoken=CdidpKSGbLxzmOXnbmlkvrZep1eJmKLAA81T73UjcjxEnMOa4YOZqtc849AkYfUy;session=xxxx'
    # {'csrftoken': 'CdidpKSGbLxzmOXnbmlkvrZep1eJmKLAA81T73UjcjxEnMOa4YOZqtc849AkYfUy'}
     

    # 6.requests中其他值(路由匹配成功后)
    print(request.resolver_match)

    return HttpResponse("login")

2、3返回值

  • HttpResponse

  • JsonResponse

  • render

  • redirect

  • from django.shortcuts import HttpResponse, redirect, render
    from django.http import JsonResponse
    
    
    def auth(request):
        pass
    
    
    def login(request):
        # 1.获取请求数据
        print(request)
    
        # 2.根据请求数据进行条件的判断 GET/POST   GET.get("xx")    POST.get("xx")
    
        # 3.返回数据
    
        # 3.1 字符串/字节/文本数据(图片验证码)
        return HttpResponse("login")
    
        # 3.2 JSON格式(前后端分离、app小程序后端、ajax请求)
         data_dict = {"status": True, 'data': [11, 22, 33]}
         return JsonResponse(data_dict)
    
        # 3.3 重定向
         return redirect("https://www.baidu.com")
         return redirect("http://127.0.0.1:8000/api/auth/")
         return redirect("http://127.0.0.1:8000/api/auth/")
         return redirect("/api/auth/")
         return redirect("/api/auth/")  # name
        
         from django.urls import reverse
         url = reverse("auth")
         return redirect(url)  # name
         return redirect("auth")
    
        # 3.4 渲染
        # - a.找到 'login.html' 并读取的内容,问题:去哪里找?
        # -   默认先去settings.TEMPLATES.DIRS指定的路径找。(公共)
        # -   按注册顺序每个已注册的app中找他templates目录,去这个目录中寻找'login.html'
        # -   一般情况下,原则,那个app中的的模板,去哪个那个app中寻找。
        # - b.渲染(替换)得到替换完成的字符串
        # - c.返回浏览器
        return render(request, 'api/login.html')

    2、4 响应头

  •   往响应头里加入自定义数据
  • from django.shortcuts import HttpResponse, redirect, render
    from django.http import JsonResponse
    
    
    def login(request):
        res = HttpResponse("login")
        res['xx1'] = "hahaha"
        res['xx2'] = "hahaha"
        res['xx3'] = "hahaha"
    
        res.set_cookie('k1',"aaaaaaaa")
        res.set_cookie('k2',"bbbbbb")
    
        return res

2、5 响应体就是浏览器展示的内容

2、6 FBV和CBV

         pass

你可能感兴趣的:(django,python,后端)