Django基础讲解-路由控制器和视图(Django-02)

这篇具有很好参考价值的文章主要介绍了Django基础讲解-路由控制器和视图(Django-02)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一 路由控制器

参考链接: Django源码阅读:路由(二) - 知乎

Route路由, 是一种映射关系!路由是把客户端请求的 url路径与视图进行绑定 映射的一种关系。

Django基础讲解-路由控制器和视图(Django-02),全栈系列,django,python,后端

这个/timer通过路由控制器最终匹配到myapp.views中的视图函数 timer

Django基础讲解-路由控制器和视图(Django-02),全栈系列,django,python,后端

在django中所有的路由最终都被保存到一个变量 urlpatterns, urlpatterns必须声明在主应用下的urls.py总路由中。这是由配置文件settings设置的。

在django运行中,当客户端发送了一个http请求到服务端,服务端的web服务器则会从http协议中提取url地址, 从程序内部找到项目中添加到urlpatterns里面的所有路由信息的url进行遍历匹配。如果相等或者匹配成功,则调用当前url对象的视图方法。

在给urlpatterns路由列表添加路由的过程中,django一共提供了2个函数给开发者注册路由,字符串路由和正则路由

from django.urls import path      # 字符串路由
from django.urls import re_path   # 正则路由,会把url地址看成一个正则模式与客户端的请求url地址进行正则匹配

# path和re_path 使用参数一致.仅仅在url参数和接收参数时写法不一样

1.1 基本使用

path and re_path 两种路由的使用:

# 只要请求路径和正则匹配成功就会执行视图函数~
path(r'^articles/2003/$', views.special_case_2003),
re_path(r'^articles/([0-9]{4})/$', views.year_archive),# $ 符 不会被上面的覆盖掉 上面的就匹配不成功了
# 1、简单分组 ([0-9]{4})  ([0-9]{2})  是按位置传参的 和参数位置有关
re_path(r'^articles/([0-9]{4})/([0-9]{2})/$', views.month_archive),#加个小括号是正则的简单分组 符合小括号的正则内容 会按形参入到视图函数中 函数也要接收~

# 2、有名分组 ?P<year>  ?P<month> 是按关键字传参的 和参数位置无关 视图函数形参的参数名要保持一直
re_path(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.month_archive2),

'''
re_path(r'^articles/(\d{4}/(\d{1,2})/$',articles_archive_by_month)
请求路径:/articles/2010/12
# 简单分组
re.findall("articles/(\d{4}/(\d{1,2})","/articles/2010/12") # 左边是规则 后面是请求路径 
一旦匹配成功:调用articles_archive_by_month(request,2010,12) # (\d{4}/(\d{1,2})分组了 就会传参 视图函数就会在数据库里进行查询

# 有名分组
一旦匹配成功:
if 简单分组:
    调用articles_archive_by_month(request,2010,12)  # 位置传参
else if 有名分组:
    调用articles_archive_by_month(request,year = 2010,month = 12) # 关键字传参
'''

1.2 路由分发

from django.urls import path, re_path, include

path('api/', include('erp_system.urls')),
path('api/', include('basic_info.urls')),
path('api/', include('goods_info.urls')),
path('api/', include('purchase_info.urls')),
path('api/', include('warehouse_info.urls')),

1.3 反向解析

在使用Django 项目时,一个常见的需求是获得URL 的最终形式,以用于嵌入到生成的内容中(视图中和显示给用户的URL等)或者用于处理服务器端的导航(重定向等)。人们强烈希望 不要硬编码这些URL(费力、不可扩展且容易产生错误)或者设计一种与URLconf 毫不相关的专门的URL 生成机制,因为这样容易导致一定程度上产生过期的URL。

反向解析:就是路由不想写死

在需要URL 的地方,对于不同层级,Django 提供不同的工具用于URL 反查:

在模板中:使用url模板标签

在Python 代码中:使用from django.urls import reverse 函数。(视图函数重定向中写url时)

urls.py中为url设置别名参数:

from django.conf.urls import url
from . import views

urlpatterns = [
    #...name='news-year-archive'
    url(r'^articles/([0-9]{4})/$', views.year_archive, name='news-year-archive'),
    #...
]

应用之在模板中反向解析: {% url 'news-year-archive' 2012 %} 别名:'news-year-archive' 正则参数:2012。

<a href="{% url 'news-year-archive' 2012 %}">2012 Archive</a>
<a href="/articles/2012/">2012 Archive</a>
from django.shortcuts import redirect
from django.urls import reverse

def redirect_to_year(request):
    year = 2006
    reverse_path=reverse('news-year-archive', args=(year,))
    return redirect(reverse_path)  # 等效 redirect("/articles/2006/")

二 视图

Django的视图主要有2种,分别是视图函数视图类 ,现在我们先从视图函数(FBV)进行入手,后面再学习视图类(CBV)

  • Function BaseView:函数基本视图

  • Class BaseView:类基本视图

2.1 请求方式

web项目运行在http协议下,默认肯定也支持用户通过不同的http请求发送数据来。django支持让客户端只能通过指定的Http请求来访问到项目的视图。

home/views.py

# 让用户发送POST才能访问的内容
from django.views.decorators.http import require_http_methods
@require_http_methods(["POST"])
def login(request):
    # 获取请求方式 GET/POST
    print(request.method)
    # 获取请求体数据
    print(request.body) # 一个字符串,代表请求报文的请求体的原数据
    print(request.POST) # 只有请求数据格式是 urlencoded 时才能获取到
  
    # 获取具体数据
    user = request.POST.get("user")# get()获取键对应值的列表里的最后一个元素
    hobby = request.POST.getlist("hobby")# 获取值列表里的所有元素
    return HttpResponse("登录成功!")

路由绑定,demo/urls.py,代码:

from django.contrib import admin
from django.urls import path
from home.views import timer
urlpatterns = [
    path('admin/', admin.site.urls),
    path("timer", timer),
    path("login", login),
]

2.2 请求对象

django将请求报文中的请求行、首部信息、内容主体封装成 HttpRequest 类中的属性。 除了特殊说明的之外,其他均为只读的。

HttpRequest 对象包含当前请求URL的一些信息:

Django基础讲解-路由控制器和视图(Django-02),全栈系列,django,python,后端

# 进入注册页面的视图函数
@require_http_methods(["GET"])
def register(request):
    print('进入register视图函数')
    user_id = request.GET['id']
    print(user_id, type(user_id))
    return HttpResponse(f'你传入的用户ID是:{user_id}')

2.2.1 请求方式

print(request.method)

2.2.2 请求数据

1. HttpRequest.GET:一个类似于字典的对象,包含 HTTP GET 的所有参数。详情请参考 QueryDict 对象。

2. HttpRequest.POST:一个类似于字典的对象,如果请求中包含表单数据,则将这些数据封装成 QueryDict 对象。# 注意:键值对的值是多个的时候, # 比如checkbox类型的input标签,select标签,需要用:request.POST.getlist("hobby")。
3. HttpRequest.body:一个字符串,代表请求报文的请求体的原数据。

2.2.3 请求路径

HttpRequest.path:  表示请求的路径组件(不含get参数)只是路径部分。
HttpRequest.get_full_path():含get参数的路径。

2.2.4 请求头

HttpRequest.META:一个标准的Python 字典,包含所有的HTTP 首部。具体的头部信息取决于客户端和服务器,HttpRequest.META.get('HTTP_HOST')。

2.3 响应对象

响应对象主要有三种形式:

HttpResponse()     # 响应基础类
JsonResponse()     # json格式的响应 (接口编程,DRF)

render()     # 内核都是HttpResponse()

redirect()   # 内核都是HttpResponse()

2.3.1 HttpResponse()

Django服务器接收到客户端发送过来的请求后,会将提交上来的这些数据封装成一个 HttpRequest 对象传给视图函数。那么视图函数在处理完相关的逻辑后,也需要返回一个响应给浏览器。

而这个响应,我们必须返回 HttpResponseBase 或者他的子类的对象。而 HttpResponse 则是 HttpResponseBase 用得最多的子类。

return HttpResponse("登录成功!",status=404,content_type='text/plain')

常用属性:

content:返回的内容。

status_code:返回的HTTP响应状态码。

content_type:返回的数据的MIME类型,默认为 text/html 。浏览器会根据这个属性,来显示数据。如果是 text/html ,那么就会解析这个字符串,如果 text/plain ,那么就会显示一个纯文本。

设置响应头: response['X-Access-Token'] = 'xxxx' 。

2.3.1.2 JsonResponse类:

用来对象 dump 成 json 字符串,然后返回将 json 字符串封装成 Response 对象返回给浏览器。并且他的 Content-Type 是 application/json 。示例代码如下:

from django.http import JsonResponse

def index(request):
    book = {"title":"三国演义","price":199}
    books = [{"title":"三国","price":99},{"title":"三国演义","price":199}]
    # JsonResponse(book)本质 是先序列化json.jump, ensure_ascii=False 使数据正常显示 。content_type='application/json' 声明一下响应类型
    # return HttpResponse(json.jump(book,ensure_ascii=False),content_type='application/json')
    # return JsonResponse(book) # 默认是序列化一个字典
  
    return JsonResponse(books,safe=False) # 序列化一个非字典数据(列表)

默认情况下 JsonResponse 只能对字典进行 dump ,如果想要对非字典的数据进行 dump ,那么需要给 JsonResponse 传递一个 safe=False 参数。

2.3.2 render() 渲染函数

render(request, template_name,[context])
#结合一个给定的模板和一个给定的上下文字典,并返回一个渲染后的 HttpResponse 对象。\
render(request,'users/index.html',['ip':2013])

参数:

/*
 request: 用于生成响应的请求对象。ip
 template_name:要使用的模板的完整名称,可选的参数。模板文件非html文件因为里面有模板语句{{ip}},渲染后呈现在浏览器中的才是htm页面
 context:添加到模板上下文的一个字典,
          默认是一个空字典。如果字典中的某个值是可调用的,视图将在渲染模板之前调用它。
 */

render方法就是将一个模板页面中的模板语法进行渲染,最终渲染成一个html页面作为响应体。

2.3.3 redirect方法 (重定向)

当您使用Django框架构建Python Web应用程序时,您在某些时候必须将用户从一个URL重定向到另一个URL,通过redirect方法实现重定向。

参数可以是:

  • 一个绝对的或相对的URL, 将原封不动的作为重定向的位置.

  • 一个url的别名: 可以使用reverse来反向解析url

# 传递要重定向到的一个具体的网址
def my_view(request):
    ...
    return redirect("/some/url/")
# 当然也可以是一个完整的网址
def my_view(request):
    ...
    return redirect("http://www.baidu.com")
# 传递一个视图的名称
def my_view(request):
    ...
    return redirect(reverse("url的别名"))

重定向 会有两次请求 第一次返回一个响应头location:/index/ (/index/ 是 resirect里写的相对路径) code:301 只要浏览器读取到301或302 就会发起新的请求 第二次返回一个index.html页面。

Django基础讲解-路由控制器和视图(Django-02),全栈系列,django,python,后端

APPEND_SLASH的实现就是基于redirect,默认补充浏览器请求路径的 / 在setting文件中配置 APPEND_SLASH=False 将默认补充关闭。

三 登录验证案例

Django基础讲解-路由控制器和视图(Django-02),全栈系列,django,python,后端文章来源地址https://www.toymoban.com/news/detail-727498.html

3.1 html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

/*/users/auth 相对路径一定要加第一个/*/
<form action="/user/auth" method="post">
    用户名<input type="text" name="user">
    密码 <input type="password" name="pwd">
    /*span标签提示错误信息*/
    <input type="submit"> <span style="color: red">{{ msg }}</span>
</form>
</body>
</html>

3.2 路由配置

from django.contrib import admin
from django.urls import path, re_path,include

from users.views import login,auth
urlpatterns = [
    path("login",login),
    path("auth",auth),
]

3.3 视图函数

def login(request):
    return render(request,"login.html")

def auth(request):
    #  获取数据
    print("request.POST:",request.POST)

    user = request.POST.get("user")
    pwd = request.POST.get("pwd")

    # 模拟数据校验
    if user == "laomao" and pwd == "123456":
        # return HttpResponse("验证通过")
        return redirect("/users/")
    else:
        # return HttpResponse("用户名或者密码错误")
        # return redirect("/users/login")
        # 重定向适合动态页面 静态页面可以用render
        # 静态页面渲染一些信息一般用render
        msg = "用户名或者密码错误"
        return render(request,"login.html",{"msg":msg})

到了这里,关于Django基础讲解-路由控制器和视图(Django-02)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Mininet】基础篇:开源控制器POX

    大家好,我是文思月! 每文一言:时间不在于你拥有多少,而在于你如何使用! 本篇文章主要是基于POX控制器进行的两个实验:一个是使交换机模拟hub(集线器)的功能,一个是让交换机实现L2自学习。POX是一个SDN控制器,编程语言是python。 在开始之前,首先需要在ubuntu中

    2024年02月08日
    浏览(24)
  • 固定时间收敛的控制器设计(基础知识)

    本篇文章主要描述在设计固定时间控制器时,所采用的一些引理。 考虑如下非线性自治系统 x ˙ = f ( x ) , x ( 0 ) = x 0 dot{x}=f(x),quad x(0)=x_0 x ˙ = f ( x ) , x ( 0 ) = x 0 ​ 其中 x ∈ R n xinmathbb{R}^n x ∈ R n 表示状态; f : D → R n f:mathbb{D}tomathbb{R}^n f : D → R n 表示在原点的开邻域

    2023年04月10日
    浏览(41)
  • 飞天使-k8s基础组件分析-控制器

    控制器含义解释 pod的标签与注释 ReplicaController ReplicaSet Deployments DaemonSet Job Cronjob 参考文档

    2024年02月11日
    浏览(32)
  • 生动的SDN基础内容介绍(三)--Ryu控制器

    之前介绍完了南向协议OpenFlow,这次说一说Ryu。因为毕设的时候师兄推荐了Ryu,再考虑到Python方便开发,我也就继续用Ryu了。但是后续发现好像支持Ryu开发的框架相较Floodlight、OpenDaylight、ONOS没那么多(但也可能只是我没找到)。 首先非常强烈推荐这位大哥的博客: https://w

    2023年04月15日
    浏览(32)
  • CAN总线基础详解以及stm32的CAN控制器

    目录 CAN简介 CAN总线拓扑图 CAN总线特定 CAN应用场景 CAN的物理层 CAN的协议层 CAN数据帧介绍 CAN位时序介绍 数据同步过程 硬件同步 再同步 CAN总线仲裁 stm32的CAN控制器 CAN控制器介绍 CAN控制器模式 CAN控制器框图 接收过滤器 CAN控制器波特率计算 CAN相关寄存器 CAN主控制寄存器(

    2024年01月25日
    浏览(34)
  • 【Three.js基础】创建场景、渲染场景、创建轨道控制器(一)

    🐱 个人主页: 不叫猫先生 🙋‍♂️ 作者简介:前端领域新星创作者、阿里云专家博主,专注于前端各领域技术,共同学习共同进步,一起加油呀! 💫系列专栏:vue3从入门到精通、TypeScript从入门到实践 📢 资料领取:前端进阶资料以及文中源码可以找我免费领取 🔥 前端

    2024年02月01日
    浏览(43)
  • Linux Kernel入门到精通系列讲解(QEMU-虚拟化篇) 2.2 新增加CPU外设之UART、中断控制器和pFLASH

    上一章节我们将 CPU 和部分 memory 已经初始化完成了,具体实现可以查看代码仓库,本章节我们将在上一章节的基础之上去增加 pFlash 设备(作为初始化完 ROM 后的第一个代码存储区)、中断控制器和 UART 设备。

    2024年04月25日
    浏览(25)
  • Three.js基础入门介绍——Three.js学习三【借助控制器操作相机】

    在Three.js基础入门介绍——Three.js学习二【极简入门】中介绍了如何搭建Three.js开发环境并实现一个包含旋转立方体的场景示例,以此为前提,本篇将引进一个控制器的概念并使用”轨道控制器”(OrbitControls)来达到从不同方向展示场景内容的效果。 Three.js的控制器 three.js的核

    2024年02月04日
    浏览(45)
  • 【Unity游戏开发教程】零基础带你从小白到超神16——四种方法控制人物移动之角色控制器

    直接修改组件位置 去资源商城下载角色控制系统成品直接拿来用 unity提供的角色控制器组件 通过物理系统自己做

    2024年02月08日
    浏览(36)
  • 第21章_瑞萨MCU零基础入门系列教程之事件链接控制器ELC

    本教程基于韦东山百问网出的 DShanMCU-RA6M5开发板 进行编写,需要的同学可以在这里获取: https://item.taobao.com/item.htm?id=728461040949 配套资料获取:https://renesas-docs.100ask.net 瑞萨MCU零基础入门系列教程汇总 : https://blog.csdn.net/qq_35181236/article/details/132779862 本章目标 了解ELC基本概念

    2024年02月08日
    浏览(30)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包