Django 学习第九天——请求与响应

时间:2024-01-18 15:47:08

一、HttpRequest 对象:

  服务器接收到http协议的请求后,会根据报文创建 HttpRequest 对象视图函数的第一个参数是HttpRequest 对象再django.http 模块中定义了 HttpRequest 对象的 API

  HttpRequest 的属性:

    path:一个字符串,表示请求的页面的完整路径,不包含域名;

    method:一个字符串,表示请求使用的HTTP方法,常用值包括:'GET','POST'

    encoding:一个字符串,表示提交数据的编码方式;

      如果为None则表示使用浏览器的默认设置,一般为 utf-8

      这个属性是可写的,可以通过修改它来修改访问表单数据使用的编码,接下来对属性的任何访问使用新的 encoding 值

    GET:一个类似于字典的对象,包含 get 请求方式的所有参数;

    POST:一个类似于字典的对象,包含 post 请求方式的所有参数;

    FILES:一个类似于字典的对象,包含所有的上传文件;

    COOKIES:一个标准的python字典,包含所有的 cookie,键和值都为字典;

    SESSION:一个既可读又可写的类似于字典的对象,表示当前的会话,只有当 django 启用会话的支持是才有可用;

    is_ajax():如果请求是通过 XMLHttpRequest 发起的,则返回 True;

二、GET 和 POST请求:

  form 标签中的 GET 和 POST:

    在HTML中,form表单的作用是收集标签中的内容,<form>...</form> 中间可以由访问者添加类似于文本,选择,或者一些控制模块等等.然后这些内容将会被送到服务端

    一个表单必须指定两样东西;

      1、form 的 method 参数用于设置表单的提交方式,默认使用post

      2、action 用于设置表单的提交 url ,如果不写或者保持空字符串,那么将使用当前的url

  form 表单使用 GET 方式提交的例子:

  模板:

Django 学习第九天——请求与响应

视图:

Django 学习第九天——请求与响应

url:

Django 学习第九天——请求与响应

前端:(get 方式提交数据会在 url 中显示)

Django 学习第九天——请求与响应

    1、get 提交的参数会在 url 中显示;

    2、可以通过 request.GET.get() 的方法来获取提交的参数;

  form 表单使用 POST 方式提交的例子:

    模板

Django 学习第九天——请求与响应

  视图:

Django 学习第九天——请求与响应

  url:

Django 学习第九天——请求与响应

  前端:(post 方式提交数据不会再 url 中显示)

Django 学习第九天——请求与响应

    1、post 提交的方式不会在 url 中显示;

    2、可以通过 request.POST。get() 的方式来获取提交的数据;

    3、django 保护机制;必须要在模板上加入 {% csrf_token %} 防止 csrf 攻击(跨站请求伪造)

  一键多值的 getlist 方法:

    request对象的属性GET、POST都是QueryDict类型的对象;与python字典不同,QueryDict类型的对象用来处理同一个键带有多个值的情况

    get() 方法:

      根据键获取值,只能获取键的一个值;

      如果一个键同时拥有多个值,获取最后一个值;

    getlist() 方法:

      根据键获取值将键的值以列表返回;

      可以获取一个键的多个值;

    例:

      在模板中写上携带 get 参数的 url:

Django 学习第九天——请求与响应

    视图中获取参数:

Django 学习第九天——请求与响应

  request 中 GET 和 POST 对象的属性:

    GET 属性:

      QueryDict 类型的对象

      包含 get 请求方式的所有参数

      与url请求地址中的参数对应,位于 ? 后面

      参数的格式是键值对,如 key1=value1

      多个参数之间,使用 & 连接,如 key1=value1&key2=value2

    POST 属性:

      QueryDict类型的对象

      包含 post 请求方式的所有参数

      与 form 表单中的控件对应

      表单中控件要有 name 属性,则 name 属性的值为键,value 属性的值为值,构成键值对提交

      对于 checkbox 控件,name 属性一样为一组,当控件被选中后会被提交,存在一键多值的情况.

  GET 和 POST 请求方式总结:

    1. GET:GET如其名,是从服务器获取数据,不会更改服务器的状态和数据,在URL中携带参数发送给服务器。

    2. POST则是将一定量的数据发送给服务器,一般会更改服务器的数据。

    3. POST方法的参数不能在URL当中看到,他是通过body参数传递给服务器的,所以相对GET方法直接能在URL当中看到传递的参数,显得更加安全一些.当然,也不能简单的判定POST方法比GET方法更安全,要使网站保持安全,需要做更多的安全处理.

三、文件上传:

  Django 在处理文件上传的时候,文件数据被保存在了 request.FILES

  FILES 中的每个键为 <input type="file" name="" /> 中的 name

  设置文件的存储路径:

    1.在项目根目录下 static 中创建 xxx 文件夹

    2.图片上传后,会被保存到 “/static/xxx/ 文件”

    3.打开 settings.py 文件,增加 XXX_ROOT 项

    Django 学习第九天——请求与响应

  文件上传 from 表单中:

Django 学习第九天——请求与响应

      FILES 只有在请求的方法为 POST 且提交的<form> 带有 enctype="multipart/form-data" 的情况下才会包含数据。否则,FILES 将为一个空的类似于字典的对象

  文件上传视图函数:

Django 学习第九天——请求与响应

四、HttpRespond 对象:

  属性:

    content:表示返回的内容,字节型;

    charset:表示 response 采用的编码字符集,字符串类型;

    status_code:响应的 HTTP 响应状态嘛;

    content-type:指定输出的 MIME 类型;

  方法:

    init:使用页面内容实例化 HttpResponse 对象;

    write(content):以文件的方式写;

    flush():以文件方式输出缓存区;

    set_cookie(key,value=' ',max_age=None,expires=None):设置 cookie ;

      key,value 都是字符串

      max_age 是一个整数,表示在指定秒后过期;

      expires 是一个 datetime 或 timedelta 对象,会话将在这个指定的 日期/时间 过期,注意 datetime 和 timedelta 值只有在使用 PickleSerializer 时才可序列化;

        max_age 与 expires 二选一;如果不指定过期时间,则关闭浏览器就失效;

    delete_cookie(key):删除指定 key 的 cookie,如果 key 不存在则什么也不发生;

  HttpResponse 的子类:

    返回数据的响应函数有:

      HttpResponse() 返回简单的字符串对象

      render() 渲染模板

      redirect() 重定向

      JsonResponse() 返回json数据(只能就收字典对象)

Django 学习第九天——请求与响应

  HTTP 协议:

    HTTP(超文本传输协议)是一个应用层协议,由请求和响应构成,是一个标准的客户端服务器模型。HTTP是一个无状态的协议。