zoukankan      html  css  js  c++  java
  • HTTP请求method以及头信息

    HTTP协议定义了很多与服务器交互的方法

    HTTP1.0中定义了三种请求的方法:GET、POST、HEAD方法;

    HTTP1.1中新增了六种请求方法:OPTIONS、PUT、PATCH、DELETE、TRACE和CONNECT方法。

    (1)Options:允许服务器针对特定资源所支持的HTML请求方法,或web服务器发送测试服务器功能(允许客户端查看服务器性能)

    (2)Get:向特定资源发送请求并返回实体主体;

    (3)Post:提交数据

    (4)Put:上传最新数据

    (5)Head:与get请求类似,但是不会返回响应主体,用于获取报头信息

    (6)Delete:请求服务器删除页面

    (7)Trace:回显服务器收到的请求,用于测试和诊断

    (8)Connect:HTTP1.1协议中能够将连接改为管道方式的代理服务器。

    这里详细说一下HTTP跨域前的预请求OPTIONS

      OPTIONS请求方法的主要用途有两个:

      一、获取服务器支持的HTTP请求方法。

      客户端可以对特定的URL使用OPTIONS方法,也可以对整站使用该方法。

      

      响应报文中包含Allow首部字段,该字段的值表明了服务器所支持的所有HTTP方法。

           

      二、用来检查服务器的性能。

      对于AJAX跨域请求,CORS规范要求,对那些可能对服务器数据产生副作用的HTTP请求方法(特别是GET以外的HTTP请求),浏览器必须首先使用OPTIONS方法发起一个预检请求,从而获知服务器是否允许该跨域请求。

      CORS的两种请求方式:简单请求和非简单请求。

      浏览器什么情况下能预检?----->发送非简单请求    (跨域且非简单请求)

      同时满足一下三大条件就属于简单请求,否则属于非简单请求。

      (1)请求方式只能是GET、POST、HEAD

      (2)HTTP请求头限制这几种字段:Accept、Accept-Language、Content-Language、Content-Type、Last-Event-ID

      (3)Content-type只能取:application/x-www-form-urlencoded、multipart/form-data、text/plain

      

      对于简单请求,浏览器直接请求,会在请求头信息中,增加一个origin字段,来说明本次请求来自哪个源,服务器根据这个值来决定是否同意该请求。

      如果origin指定的源不在许可范围内,服务器会返回一个正常的HTTP响应。浏览器发现,这个响应头信息中没有包含Access-Control-Allow-Origin字段,就知道出错了,从而抛出一个错误,被XMLHttpRequest的onerror函数捕获。注意,这种错误无法通过状态码识别,因为可能返回的是200。

      如果origin指定的域名在许可范围内,服务器返回的响应头会多出几个字段,都是以Access-Control-开头。

      (1)Access-Control-Allow-Origin

      这个字段是必须的,表示接受任意域名的请求。

      需要注意的是,如果要发送Cookie,Access-Control-Allow-Origin的值就不能设为*,必须指定明确的、与请求网页一致的域名。只有用服务器域名设置的Cookie才会上传,其他域名的Cookie并不会上传。

      (2)Access-Control-Allow-Credentials

      该字段可选,表示是否允许发送Cookie。默认情况下,Cookie不包括在CORS请求值中。这个值只能设为true,如果服务器不要浏览器发送Cookie,删除该字段即可。

      (3)Access-Control-Expose-Headers

      该字段可选,CORS请求时,XMLHttpRequest对象的getResponseHeader()方法只能拿到6个基本字段:Cache-Control、Content-Language、Content-Type、Expires、Last-Modified、Pragma。如果想要拿到其他字段,必须在这里指定。

      非简单请求是对服务器有特殊要求的请求,比如请求方式是PUT或者DELETE,或者Content-Type字段的值为application/json。都会在正式通信之前,增加一次HTTP请求,称之为预检。浏览器会先询问服务器,当前网页所在的域名是否在服务器的许可名单之中。服务器允许后,浏览器会正式发出XMLHttpRequest请求,否则会报错。

    HTTP头信息

    HTTP的头信息包括通用头、请求头、响应头和实体头四个部分。每个头域由一个域名、冒号和域值三部分组成。

    1、通用头部:是客户端和服务器都可以使用的头部,通用头域包含Cache-Control、 Connection、Date、Pragma、Transfer-Encoding、Upgrade、Via。

    2、请求头部:是请求报文特有的,他们为服务器提供一些额外信息,比如客户端希望接收什么类型的数据,如Accept头部。

    3、响应头部:便于客户端提供信息,比如客户端在与哪种类型的服务器进行交互,如Server头部。

    4、实体头部:用于应对实体主体部分的头部。比如可以在实体头部来说明实体主体部分的数据类型,如Content-type头部。

    *1,HTTP请求头和响应头的含义

    请求头:

    (1)Accept         告诉WEB服务器自己接受什么样的介质类型。

    •   Accept:text/xml  代表客户端希望接收的数据类型是xml类型
    •   Accept:application/json  代表客户端希望接收的数据类型是json类型

    (2)Accept-Charset: ISO-8859-1(浏览器可以接收的编码类型)

    (3)Accept-Encoding: gzip,compress(浏览器可以接收压缩编码类型)       浏览器申明自己接收的编码方式

    (4)Accept-Language: en-us,zh-cn(浏览器可以接收的语言和国家类型)

    (5)Host: www.it315.org:80(浏览器请求的主机和端口)

    (6)Referer: http://www.it315.org/index.jsp(请求来自于哪个页面)

    (7)Origin:请求源,指示请求来自于哪个站点,该字段并不包含任何页面路径信息(截止到端口)

          该首部用于跨域请求或者POST请求,除了不包含路径信息,该字段与Referer字段相似。

    (8)User-Agent: Mozilla/4.0 (用户代理的字符串值)

    (9)Cookie:(浏览器暂存服务器发送的信息)

    (10)Connection: 请求:

    •   Connection:close(告诉服务器在完成本次请求的响应后,断开连接,不要等待本次连接的后续请求) http1.0
    •   Connection:keep alive(在完成本次请求后,保持连接,等待本次连接的后续请求)    http1.1

         设置连接时间:keep-Alive:timeout=5,max=1000

         timeout是超时时间,单位是s,超过这个时间后就断开连接;max是最多的连接次数,若超过这个次数就强制断开连接。

    (11)Date: Tue, 11 Jul 2000 18:23:51 GMT(请求发送的日期和时间)

    (12)Cache-Control:浏览器应遵循的缓存机制。

    (13)If-Modefined-Since:允许在对应的资源未被修改的情况下返回304未修改      对应响应头的Last-Modefined

    (14)If-None-Match:允许在对应的资源未被修改的情况下返回304未修改             对应响应头的ETag

    响应头:

    (1)Location: http://www.it315.org/index.jsp(用于重定向接收者到一个新的URL地址)

    (2)Server:apache tomcat(服务器的类型)

    (3)Content-Encoding: gzip(服务器发送的压缩编码方式)

    (4)Content-Length: 80(服务器发送显示的字节码长度)

    (5)Content-Language: zh-cn(服务器发送内容的语言和国家名)

    (6)Content-Type: image/jpeg; charset=UTF-8(服务器发送内容的类型和编码类型)

    (7)Set-Cookie:SS=Q0=5Lb_nQ; path=/search(服务器发送Cookie相关的信息)

    (8)Expires: 设置响应报文的过期时间

    (9)Cache-Control:服务器应遵循的缓存机制。

        Cache-Control:no-cache(服务器控制浏览器不要缓存网页)

    (10)Last-Modefined:服务器通过这个头告诉浏览器,缓存资源的最后修改时间

    (11)ETag:缓存相关的头,为每一个资源分配唯一的编号

    (12)Pragma: no-cache(服务器控制浏览器不要缓存网页)  

    (13)Connection: close/Keep-Alive(HTTP请求的版本的特点)  

    (14)Date: Tue, 11 Jul 2000 18:23:51 GMT(响应网站的时间)

    (15)Status:响应状态

    Accept与content-type的区别

    (1)类型不同,Accpet属于请求头,content-type属于实体头(客户端与服务器端均存在)

    (2)作用不同,Accept代表客户端希望接收的数据类型;content-type代表发送端(客户端|服务器端)发送的实体数据的数据类型。

    两者合起来,Accept:text/xml;Content-type:text/html 代表希望接收的数据类型是xml格式,本次请求的数据的数据格式是html。

    Content-type常见的几种值:   使用content-type来表示具体请求中的媒体类型信息。

    常见的媒体格式类型:

      text/html:HTML格式

      text-plain:纯文本格式

      text/xml:XML格式

      image/gif:gif图片格式

      image/jpeg:jpg图片格式

      image/png:png图片格式

    以application开头的媒体格式类型:

      application/xhtml+xml:XHTML格式

      application/xml:XML数据格式

      application/json:json数据格式

    application/json与application/x-www-form-urlencoded的区别

    application/json的作用是告诉服务器发送内容是json格式的字符串,服务器会对json字符串进行解析;

    application/x-www-form-urlencoded是jQuery的Ajax请求默认方式,在请求发送的过程中会对数据进行序列化处理,以键值对的方式。

  • 相关阅读:
    模拟112 题解
    python 虚拟环境--virtualenv
    Flask基础
    通过yum安装mysql数据
    Python中function(函数)和methon(方法)的区别
    Django之路由分发系统
    OpenGL Shader in OpenCASCADE
    A Simple OpenGL Shader Example II
    Make Helix Curve in OpenCASCADE
    A Simple OpenGL Shader Example
  • 原文地址:https://www.cnblogs.com/xiaoan0705/p/8961181.html
Copyright © 2011-2022 走看看