Backend - Django URL 路由 & 重定向 & url编码解码

目录

[一、url 的 <> 作用](#一、url 的 <> 作用)

(一)操作流程

(二)前端设置链接

[1. 包括:](#1. 包括:)

[2. 比如](#2. 比如)

(三)后端匹配路由

[1. 理解](#1. 理解)

[2. 比如](#2. 比如)

[(三)后端视图的 get( )的参数](#(三)后端视图的 get( )的参数)

[1. 理解](#1. 理解)

[2. 比如](#2. 比如)

[二、路由重定向 HttpResponseRedirect](#二、路由重定向 HttpResponseRedirect)

(一)重定向到当前操作界面(刷新该界面)

(二)重定向到指定界面

(三)重定向时,带参数

[1. 指定跳转时](#1. 指定跳转时)

[2. 获取时](#2. 获取时)

三、重定向前,获取操作页面的路由

[四、URL编码与解码,即quote() & unquote()](#四、URL编码与解码,即quote() & unquote())

[(一)quote( ) 对路由url编码](#(一)quote( ) 对路由url编码)

[1. 写法](#1. 写法)

[2. 作用](#2. 作用)

[(二)unquote( ) 对路由url解码](#(二)unquote( ) 对路由url解码)

[1. 写法](#1. 写法)

[2. 作用](#2. 作用)


一、url 的 <> 作用

(一)操作流程

前端界面templates点击链接跳转 > url路由 > views的kwargs

(二)前端设置链接

1. 包括:

ajax的url值;select的option的value值;a标签的href值等

2. 比如

html 复制代码
<a href='/url_lang/zh-hans/luobogan'></a>

(三)后端匹配路由

python 复制代码
path('url_lang/<language>/<user>/', views_base.SetLang.as_view(), name='url_set_lang'),

1. 理解

其中,< > 包裹的内容理解成一个字典的key,key对应的value是前端链接设定的值。

2. 比如

'language' 的值对应 'zh-hans', 'user' 的值对应 'luobogan' 。

(三)后端视图的 get( )的参数

python 复制代码
class SetLang(View): 
        def get(self, request, *args, **kwargs):

1. 理解

其中,第四个参数 **kwargs 的字典内容,是路由url中获取的(第二点中有提到)。

2. 比如

kwargs 的值就是字典 {'language': 'zh-hans', 'user': 'luobogan'}

二、路由重定向 HttpResponseRedirect

(一)重定向到当前操作界面(刷新该界面)

python 复制代码
from urllib.parse import unquote

nexturl = request.META.get('HTTP_REFERER')
nexturl = nexturl and unquote(nexturl)
return HttpResponseRedirect(nexturl)

(二)重定向到指定界面

python 复制代码
return HttpResponseRedirect('/url_set_lang/')

(三)重定向时,带参数

1. 指定跳转时

python 复制代码
return HttpResponseRedirect('/url_set_lang/?user_id={}&book_id={}'.format('luobo', '数据结构'))

2. 获取时

python 复制代码
request.GET.get('user_id')

三、重定向前,获取操作页面的路由

python 复制代码
request.META.get('HTTP_REFERER')   # 针对Django

理解:

当页面A跳转到页面B时,若 http 请求头包含 referer 字段,则该字段值就是页面A的 url 。

注意:

由于不同浏览器的特点,HTTP_REFERER可能会不存在。即,若要使用HTTP_REFERER,需先检查是否存在。

四、URL编码与解码,即quote() & unquote()

(一)quote( ) 对路由url编码

1. 写法

python 复制代码
from urllib.parse import quote
quote('这是一个字符串')

2. 作用

避免中文乱码。

(二)unquote( ) 对路由url解码

1. 写法

python 复制代码
from urllib.parse import unquote
unquote(my_url)

2. 作用

unquote( )方法能把 URL编码形式的字串,解码成原来的字串。

相关推荐
格鸰爱童话3 分钟前
向AI学习项目技能(六)
java·人工智能·spring boot·python·学习
悟空爬虫-彪哥7 分钟前
VRChat开发环境配置,零基础教程
python
数据知道17 分钟前
《 Claude Code源码分析与实践》专栏目录
python·ai·github·claude code·claw code
H_老邪19 分钟前
spring boot 学习之路-1.0
spring boot·后端·学习
曲幽26 分钟前
FastAPI+Vue:文件分片上传+秒传+断点续传,这坑我帮你踩平了!
python·vue·upload·fastapi·web·blob·chunk·spark-md5
树獭叔叔29 分钟前
Claude Code Skill 系统:懒加载的 Agent 行动说明
后端·aigc·openai
Nexzk34 分钟前
我把 Hermes Agent 源码扒了个底朝天:它不是“又一个 AI Agent”,而是在认真造一套代理操作系统
后端
袋鱼不重35 分钟前
Hermes Agent 安装与实战:从安装到与 OpenClaw 全方位对比
前端·后端·ai编程
写Cpp的小黑黑37 分钟前
C++ std::shared_ptr 线程安全性和最佳实践详解
后端
沸点小助手40 分钟前
「 AI 整活大赛,正式开擂 & 最近一次面试被问麻了吗」沸点获奖名单公示|本周互动话题上新🎊
前端·人工智能·后端