本文介绍: http://127.0.0.1:8000/login/ 成功​http://127.0.0.1:8000/login django重定向301http://127.0.0.1:8000/login/ 成功http://127.0.0.1:8000/login 成功​http://127.0.0.1:8000/login/ 失败http://127.0.0.1:8000/login/ 成功​http://127.0.0.1:8000/login 失败

目录

day02 django必备知识点

1.回顾

2.今日概要

3.路由系统

3.1 传统的路由

3.2 正则表达式路由

3.3 路由分发

小结

3.4 name

3.5 namespace

3.4 最后的 / 如何解决?

3.5 当前匹配对象

小结

4.视图

4.1 文件or文件夹

4.2 相对和绝对导入urls​编辑

4.3 视图参数

4.4 返回值

4.5 响应头

4.6 FBV和CBV

5.静态资源

5.1 静态文件

5.2 媒体文件


day02 django必备知识点

1.回顾

问题

  1. 虚拟环境什么时候放在项目目录下?什么时候放在别的地方?

    在F:envslearning创建环境
    在D:proj项目目录创建项目
      - day01
        pip install xxx
        pip install xxx
      - day02
      - day03
    在D:proj项目目录创建项目
      .venv
  2. 打开项目

    - 打开项目
    - 手动创建虚拟环境命令行)
    - pycharm配置项目+环境关联
    - 打开项目
    - 创建虚拟环境 + 项目和环境关联

2.今日概要

3.路由系统

本质上:URL和函数对应关系

3.1 传统路由

from django.contrib import admin
from django.urls import path
from apps.web import viewsurlpatterns = [
    path('home/', views.home),
    path('news/<int:nid>/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("文章")

3.2 正则表达式路由

3.3 路由分发

假如:200个功能

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

手动路由分发可以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.4 name

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

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

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

 

3.5 namespace

辅助name

以后再某个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/

两个扩展

赠送:

3.4 最后的 / 如何解决

APPEND_SLASH = True

path('login/', views.login),
  http://127.0.0.1:8000/login/   成功
​
  http://127.0.0.1:8000/login    django,重定向301
  http://127.0.0.1:8000/login/   成功
path('login', views.login),
  http://127.0.0.1:8000/login    成功
​
  http://127.0.0.1:8000/login    
  http://127.0.0.1:8000/login/   失败

APPEND_SLASH = False

path('login/', views.login),
  http://127.0.0.1:8000/login/   成功
​
  http://127.0.0.1:8000/login    失败
path('login', views.login),
  http://127.0.0.1:8000/login/   失败
​
  http://127.0.0.1:8000/login    成功

3.5 当前配对

什么用呀?

用户具有一些权限。   permissions = ["xx","login",'account']
某用户具有一些权限。   permissions = ["login",'account']

小结

4.视图

4.1 文件or文件夹

4.2 相对和绝对导入urls

注意实现:不要再项目根目录相对导入

原则

4.3 视图参数

urlpatterns = [
    path('login/', account.login, name="login"),
    path('auth/', order.auth, name='auth'),
]
from django.shortcuts import HttpResponse
​
​
def login(request):
    return HttpResponse("login")

request是什么呢?

对象,包裹可以放很多东西。
​
request是一个对象,存放浏览器给咱们发过来的所有内容,所以含有:
- 请求相关所有的数据当前访问的url、请求方式、...
- django额外添加数据
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&amp;v2=456'
​
    # 4.1 请求体+请求头       b'v1=123&amp;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.请求头
    # {'Content-Length': '', 'Content-Type': 'text/plain', 'Host': '127.0.0.1:8000', 'Connection': 'keep-alive', 'Cache-Control': 'max-age=0', 'Sec-Ch-Ua': '" Not A;Brand";v="99", "Chromium";v="102", "Google Chrome";v="102"', 'Sec-Ch-Ua-Mobile': '?0', 'Sec-Ch-Ua-Platform': '"macOS"', 'Upgrade-Insecure-Requests': '1', 'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/102.0.0.0 Safari/537.36', 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9', 'Sec-Fetch-Site': 'none', 'Sec-Fetch-Mode': 'navigate', 'Sec-Fetch-User': '?1', 'Sec-Fetch-Dest': 'document', 'Accept-Encoding': 'gzip, deflate, br', 'Accept-Language': 'zh-CN,zh;q=0.9,en;q=0.8,zh-TW;q=0.7', 'Cookie': 'csrftoken=CdidpKSGbLxzmOXnbmlkvrZep1eJmKLAA81T73UjcjxEnMOa4YOZqtc849AkYfUy'}
    print(request.headers)
​
    # 5.1 请求头有个特殊cookie
    # request.headers['cookie']  # 'csrftoken=CdidpKSGbLxzmOXnbmlkvrZep1eJmKLAA81T73UjcjxEnMOa4YOZqtc849AkYfUy;session=xxxx'
    # {'csrftoken': 'CdidpKSGbLxzmOXnbmlkvrZep1eJmKLAA81T73UjcjxEnMOa4YOZqtc849AkYfUy'}
    print(request.COOKIES)
​
    # 6.requests中其他值
    print(request.resolver_match)
​
    return HttpResponse("login")

4.4 返回值

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')

4.5 响应

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

4.6 FBV和CBV

  • FBV,视图用函数的形式编写(目前主流)

  • CBV,视图用类的形式编写

请注意,这一些都是表象,本质一模一样。

5.静态资源

静态资源

5.1 静态文件

INSTALLED_APPS = [
    # 'django.contrib.admin',
    # 'django.contrib.auth',
    # 'django.contrib.contenttypes',
    # 'django.contrib.sessions',
    # 'django.contrib.messages',
    'django.contrib.staticfiles',
    "apps.api.apps.ApiConfig",
    "apps.web.apps.WebConfig",
]
...
​
STATIC_URL = '/static/'
STATICFILES_DIRS = (
    os.path.join(BASE_DIR, 'static'),
)

5.2 媒体文件

urls.py

from django.contrib import admin
from django.urls import path, re_path, include
from django.conf.urls.static import static
from django.conf import settings
​
from apps.api import views
​
​
# 很多功能,很多URL
urlpatterns = [
    path('api/', include('apps.api.urls')),
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

原文地址:https://blog.csdn.net/wojiubugaosuni12/article/details/134610520

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_34726.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注