我的Django学习之路 (三) —— 请求与响应

💡前言🍀🍀

🔍上一章节中我们讲了如何引用静态文件和模板,以及如何使用常见的Django命令等。🌀🌀那么这章我们就来聊聊Django是如何向浏览器发送数据,以及我们怎么来接收浏览器返回的数据的。☀️☀️
在这里插入图片描述

💡请求🍀🍀

🐛什么是request

🔍在我们的视图函数中,每一个函数都有一个request参数,那么这个request是什么呢?request是一个对象,封装了用户通过浏览器或爬虫等发送过来的所有请求相关的数据。 注意,这里的 request 并不是 python requests模块里面的。

🐛GET与POST

🔍 GET与POST都是一种请求方式,一般我们在浏览器输入一个网址访问网站都是GET请求;在FORM表单中,可以通过设置Method指定提交方式为GET或者POST提交方式,其默认是GET提交方式。它们之间最直观的区别就是GET把参数包含在URL中;POST通过request body传递参数,它不会作为url的一部分,不会被缓存、保存在服务器日志、以及浏览器浏览记录中。(一个看得到,一个看不到)

🔍 request 有一个专门用来查看用户的请求方式的方法——method。现在就来验证下吧! 我以上次的test函数为例,添加 print(request.method)语句, 它对应的网页路径是/hd在这里插入图片描述
那么我们点击运行后访问 http://127.0.0.1:8000/hd/
在这里插入图片描述
🔍再回到我们的pycharm就能看到访问网页使用的请求方式了,果然是get请求
在这里插入图片描述
🔍 另外,我们能够通过request.GET获取网页上url传递过来的参数。怎么传递参数呢?在url后面输入“ ?”,然后就能输入参数了,多个参数用&连接。

🔍 还是以刚才的 http://127.0.0.1:8000/hd/ 为例,在后面输入?a=5&b=3变成
http://127.0.0.1:8000/hd/?a=5&b=3,最后在视图函数test使用request.GET(GET必须大写)方法接收,并打印结果。
在这里插入图片描述在这里插入图片描述
🔍 说完GET请求咱们再来结合例子说明一下POST请求。POST请求经常出现在表单中,使用时需要用method指定。我们模拟一个非常简单的用户注册界面:当我们输入完用户名和密码后,希望用两个变量接收它,方便以后存储到数据库。

🔍 先制作一个简单的HTML页面。当我们提交表单数据后,跳转至/save/页面进行保存

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <title>用户注册</title>
</head>
<body>
<h1>用户注册系统</h1>
<form method="post" action="/save/">
   <p>用户名:<input type="text" name="user" value="请输入用户名"></p>
    密  码:<input type="password" name="password"></p>
   <p><input type="submit" value="注册"></p>
</form>
</body>
</html>

🔍 接着定义两个视图函数,一个调用模板用来注册用户,一个用来保存用户信息并提示注册成功。

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


def save(request):
    user = request.POST.get("user")
    pwd = request.POST.get("password")
    print(f"用户名:{user},密码:{pwd}")
    return HttpResponse("注册成功!")

🔍 最后再新增两个路由

urlpatterns = [
    path('admin/', admin.site.urls),
    path('login/', views.login),
    path('save/', views.save)
]

🔍 现在就能开始注册啦!
先运行程序,然后进入http://127.0.0.1:8000/login/
在这里插入图片描述
🌐输入完用户名和密码后点击注册,发现…被禁用了?
在这里插入图片描述

💡csrf_token🍀🍀

🔒🔒为降低安全隐患,django专门为用户设置了一个防止跨站请求伪造(csrf)的功能——csrf_token。当在表单中用post提交数据的时候,django会去检查是否有一个csrf的随机字符串,如果没有就会报错,也就是刚才出现的页面。
因此,我们在表单中使用post传递数据时需要加上{% csrf_token %}这条命令。
🐳我们加上这条命令后重新运行进入注册网页,发现多了一串秘钥是之前没有的。
在这里插入图片描述
🐳再次输入用户名与密码,然后点击注册,就能注册成功了!接着回到pycharm也能够看到用户名跟密码都打印出来了
在这里插入图片描述

💡响应🍀🍀

🐳常见的响应形式一般有三种HttpResponse,render,redirect。前面两种我们已经使用过。

🐬 HttpResponse
可以返回简单的字符串
HttpResponse(content=响应体, content_type=响应体数据类型, status=状态码)

🐬 render
它的作用是调用模板,并能通过字典向模板传入数据。它有以下属性:

  • 🐌request:用于生成响应的请求对象。必须要写
  • 🐌template_name: 要使用的模板的完整名称。 也要写
  • 🐌context: 添加到模板上下文的一个字典. 默认是一个空字典. 如果字典中的某个值是可调用的, 视图将在渲染模板之前调用它.
  • 🐌content_type:  生成的文档要使用的MIME类型. 默认为DEFAULT_CONTENT_TYPE设置的值. 默认为"text/html"
  • 🐌status: 响应的状态码. 默认为200

🐍🐍重定向

🐤我单独把它拎出来呢是因为前面我们没有讲过重定向,因此我要举个例子说明一下。在上面的用户注册系统上稍作修改:我们注册完用户信息后不再提示用户注册成功,而是直接跳转到登录成功后的页面。

🐤在视图函数save中将原先的 return HttpResponse(“注册成功!”) 改为 return redirect("https://www.baidu.com")。点击运行后再次进入http://127.0.0.1:8000/login/
输入完用户名密码点击注册后就能跳转啦!🐥🐥
在这里插入图片描述

  • 26
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 35
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 35
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

愿此后再无WA

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值