Django_request学习

yizhihongxing

Django_request

(1)请求方式

image-20220812115203856

这里使用一个接口测试软件postman

可以看到里面有非常多的发起请求的方式,最常用的就是GETPOST请求,但是这些方法无法在网页的url里显示

image-20220828134900227

在学习request参数之前,django框架中首先接到浏览器发来的请求第一站是经过框架自带的wsgi.py文件

"""
WSGI config for djangoRegina project.

It exposes the WSGI callable as a module-level variable named ``application``.

For more information on this file, see
https://docs.djangoproject.com/en/3.2/howto/deployment/wsgi/
"""

import os

from django.core.wsgi import get_wsgi_application

os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'djangoRegina.settings')

application = get_wsgi_application()

这个文件的作用就是接收浏览器数据,进行数据解析,并按照http协议的请求格式进行封装传递给路由分发部分

(2)请求内容

def ZJR_request(request):
    #请求格式
    print(request.method)
    #请求体
    print(request.body)

image-20220828141700116

因为在get请求当中并没有参数设置,所以得到的请求体为空。如果需要加入请求体的内容,那么需要改为post请求

错误修正

  1. url错误

    image-20220828143958216

    如果发生这种错误,是因为没有在url末尾写全,必须以/结尾

    image-20220828144237585

  2. csrf

    image-20220828144313540

    CSRF # 表示django全局发送post请求均需要字符串验证
    功能:防止跨站请求伪造的功能
    工作原理:客服端访问服务器,在服务端正常返回给客户端数据的时候,而外返回给客户端一段字符串,等到客户端下次访问服务器时,服务器会到客户端查找先前返回的字符串,如果找到则继续,找不到就拒绝。
    访问流程:客户端 —> URL路由系统—> CSRF—> 视图函数
    需要在客户端页面的post表单中添:{% csrf_token%}
    setting.py里的'django.middleware.csrf.CsrfViewMiddleware'注释掉就可以了

    image-20220828144658919

image-20220828144711470

此时得到了刚刚提交的以urlencoded方式的数据,这种格式就是将普通的键值对变为用&符号连接的字符串

常用的还有通过json格式传输的键值对,选择raw选项,并在下来菜单中选择json

image-20220828145413980

这里面的字符必须使用双引号

image-20220828145557116

request.post

这个方法也是输出请求体的一种,但是需要注意的是它并不适用每一种传参格式

image-20220828154009322

这是通过urlencoded格式

image-20220828154056662

这是json格式

获取值

 name = request.POST.get("name")
 age = request.POST.get("age")
 print(name,age)

这个是必须通过urlencoded格式传参,然后通过POST方法得到具体的值

image-20220828154723900

获取值列表

image-20220828155331131如果在传参的时候一个关键字包含了多个内容,就需要getlist方法

name = request.POST.getlist("name")

image-20220828155316860

如果只用get方法,按照django自己的逻辑,只能选去这个关键字的最后一个选项

image-20220828155449219

get请求

在postman里,get请求的参数要在param里面添加

image-20220828155815454

image-20220828155854620

获取路径

print(request.path)
    print(request.get_full_path())

image-20220828160415942

如果get请求中添加了参数,那么get_full_path方法则会取到所有参数,但path方法则不会

但如果get请求里没有添加参数,两者的输出结果是一样的

image-20220828160530877

获取请求头

request.META

通过这种方法挥获得一大堆的键值对,通过解析可以获取到格式化后的内容

{
	'PATH': '/Users/ivanlee/opt/anaconda3/condabin:/usr/local/sbin:/usr/local/bin:/Library/Frameworks/Python.framework/Versions/2.7/bin:/Library/Frameworks/Python.framework/Versions/3.8/bin:/usr/local/bin:/usr/local/sbin:/Library/Frameworks/Python.framework/Versions/3.10/bin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/go/bin:/usr/local/share/dotnet:~/.dotnet/tools:/Library/Apple/usr/bin:/usr/local/mysql/bin:/usr/local/mysql/bin:/Users/ivanlee/.dotnet/tools:/usr/local/mysql/bin',
	'MANPATH': '/usr/local/share/man::',
	'CONDA_EXE': '/Users/ivanlee/opt/anaconda3/bin/conda',
	'CONDA_PYTHON_EXE': '/Users/ivanlee/opt/anaconda3/bin/python',
	'HOMEBREW_PREFIX': '/usr/local',
	'COMMAND_MODE': 'unix2003',
	'_CE_M': '',
	'LOGNAME': 'ivanlee',
	'HOMEBREW_REPOSITORY': '/usr/local/Homebrew',
	'XPC_SERVICE_NAME': 'application.com.jetbrains.pycharm.ce.24716539.38684274',
	'PWD': '/Users/ivanlee/Desktop/djangoRegina',
	'PYCHARM_HOSTED': '1',
	'INFOPATH': '/usr/local/share/info:',
	'CONDA_SHLVL': '0',
	'__CFBundleIdentifier': 'com.jetbrains.pycharm.ce',
	'PYTHONPATH': '/Users/ivanlee/Desktop/djangoRegina',
	'SHELL': '/bin/zsh',
	'PYTHONIOENCODING': 'UTF-8',
	'HOMEBREW_BOTTLE_DOMAIN': 'https://mirrors.ustc.edu.cn/homebrew-bottles',
	'OLDPWD': '/',
	'HOMEBREW_CELLAR': '/usr/local/Cellar',
	'USER': 'ivanlee',
	'TMPDIR': '/var/folders/48/byh7qq5528sfmw6vgsxnd9g80000gn/T/',
	'SSH_AUTH_SOCK': '/private/tmp/com.apple.launchd.qyJ40GUnAv/Listeners',
	'_CE_CONDA': '',
	'XPC_FLAGS': '0x0',
	'PYTHONUNBUFFERED': '1',
	'__CF_USER_TEXT_ENCODING': '0x1F5:0x0:0x0',
	'LC_CTYPE': 'en_US.UTF-8',
	'HOME': '/Users/ivanlee',
	'DJANGO_SETTINGS_MODULE': 'djangoRegina.settings',
	'TZ': 'UTC',
	'RUN_MAIN': 'true',
	'SERVER_NAME': '1.0.0.127.in-addr.arpa',
	'GATEWAY_INTERFACE': 'CGI/1.1',
	'SERVER_PORT': '8090',
	'REMOTE_HOST': '',
	'CONTENT_LENGTH': '24',
	'SCRIPT_NAME': '',
	'SERVER_PROTOCOL': 'HTTP/1.1',
	'SERVER_SOFTWARE': 'WSGIServer/0.2',
	'REQUEST_METHOD': 'POST',
	'PATH_INFO': '/JRrequest/jr/',
	'QUERY_STRING': 'name=regina',
	'REMOTE_ADDR': '127.0.0.1',
	'CONTENT_TYPE': 'application/x-www-form-urlencoded',
	'HTTP_USER_AGENT': 'PostmanRuntime/7.29.2',
	'HTTP_ACCEPT': '*/*',
	'HTTP_POSTMAN_TOKEN': 'e474691f-e449-4c99-b8ff-d6c625b6c5b6',
	'HTTP_HOST': '127.0.0.1:8090',
	'HTTP_ACCEPT_ENCODING': 'gzip, deflate, br',
	'HTTP_CONNECTION': 'keep-alive',
	'wsgi.input': < django.core.handlers.wsgi.LimitedStream object at 0x7feafca4d160 > ,
	'wsgi.errors': < _io.TextIOWrapper name = '<stderr>'
	mode = 'w'
	encoding = 'utf-8' > ,
	'wsgi.version': (1, 0),
	'wsgi.run_once': False,
	'wsgi.url_scheme': 'http',
	'wsgi.multithread': True,
	'wsgi.multiprocess': False,
	'wsgi.file_wrapper': < class 'wsgiref.util.FileWrapper' >
}

还可以从这里进行获取

print(request.META.get("HTTP_HOST"))

image-20220828230733365

自定义请求头

image-20220828230937495

这里在最后一行添加了自定义的一对键值对,提交以后我们可以看到META内容里的经过格式化的信息

image-20220828231125486

同样也可以通过get方式获得,格式写成HTTP开头

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Django_request学习 - Python技术站

(0)
上一篇 2023年4月2日 下午5:06
下一篇 2023年4月2日

相关文章

  • ajax的请求,异步,同源策略的学习

    Ajax Ajax 即“Asynchronous Javascript And XML”(异步 JavaScript 和 XML),是指⼀种创建交互式⽹⻚应⽤的⽹⻚开发技术。 Ajax 是⼀种⽤于创建快速动态⽹⻚的技术。 Ajax 是⼀种在⽆需重新加载整个⽹⻚的情况下,能够更新部分⽹⻚的技术。 通过在后台与服务器进⾏少量数据交换,Ajax 可以使⽹⻚实现异步…

    2023年4月2日
    00
  • Django_渲染详解

    Django_render 模板语法 模板引擎是一种可以让开发者把服务端数据填充到html网页中完成渲染效果的技术。它实现了把前端代码和服务端代码分离的作用,让项目中的业务逻辑代码和数据表现代码分离,让前端开发者和服务端开发者可以更好的完成协同开发。 静态网页:页面上的数据都是写死的,万年不变 动态网页:页面上的数据是从后端动态获取的(比如后端获取当前时间;…

    2023年4月2日
    00
  • CSRF和token以及用django实现

    csrf CSRF(Cross-Site Request Forgery,跨站点伪造请求)是一种网络攻击方式,该攻击可以在受害者毫不知情的情况下以受害者名义伪造请求发送给受攻击站点,从而在未授权的情况下执行在权限保护之下的操作,具有很大的危害性。具体来讲,可以这样理解CSRF攻击:攻击者盗用了你的身份,以你的名义发送恶意请求,对服务器来说这个请求是完全合法的…

    2023年4月2日
    00
  • django编写cookie

    cookie HTTP协议是一个无状态协议,即每一个请求都是独立的!无法记录前一次请求的状态,但HTTP会使用cookie值进行跟踪会话。在WEB开发当中,使用session来完成会话跟踪,session底层依赖于cookie技术。 其实cookies是由网络服务器存储在你电脑硬盘上的一个txt类型的小文件,它和你的网络浏览行为有关,所以存储在你电脑上的co…

    2023年4月2日
    00
  • django_响应对象

    Django_响应对象 响应对象 响应对象有三种形式: HttpResponse() render() Redirect() (1) HttpResponse() django服务器接收到客户端发来的请求之后,会将提交上来的数据封装成一个HttpResponse对象传给视图函数。视图函数在处理完相关逻辑之后,也需要一个返回响应给浏览器。而这个响应方式,我们必…

    2023年4月2日
    00
  • mysql面试小结

    MySQL 1. 索引 1.1 什么是索引 索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针。 索引是一种数据结构。数据库索引,是数据库管理系统中一个排序的数据结构,以协助快速查询、更新数据库表中数据。索引的实现通常使用B树及其变种B+树。 更通俗的说,索引就相当于目录。为了方便查找书中的内容,…

    MySQL 2023年4月18日
    00
  • linux下c语言的crypt函数怎么用?

    linux的crypt 最近学校布置了一个网安的小作业,要用到linux里面的这个crypt函数,写一篇总结一下。首先我们要了解这个函数是用来做什么的。 密码影子文件中存储了每一个用户的用户明文和其单向哈希过的秘文 cipher = “$1$C68vnJ27$1ttFZ1/Rylq/xi350A0NI0”; 密码字段用\(id\)salt$hashed的格式…

    Linux 2023年4月17日
    00
  • django中间件以及自定义中间件

    middleware 中间件就是在目标和结果之间进行的额外处理过程,在Django中就是request和response之间进行的处理,相对来说实现起来比较简单,但是要注意它是对全局有效的,可以在全局范围内改变输入和输出结果,因此需要谨慎使用,否则不仅会造成难以定位的错误,而且可能会影响整体性能。 中间件有什么用 如果想要修改HttpRequest或者Htt…

    2023年4月2日
    00
合作推广
合作推广
分享本页
返回顶部