Http协议格式

 Http协议格式

一、请求报文

        包括请求行、请求头和请求数据,具体格式如下:

 

 

 请求方法

        GET: 请求指定的页面信息,并返回实体主体。
        HEAD: 只请求页面的首部。
        POST: 请求服务器接受所指定的文档作为对所标识的URI的新的从属实体。
        PUT: 从客户端向服务器传送的数据取代指定的文档的内容。
        DELETE: 请求服务器删除指定的页面。
        OPTIONS: 允许客户端查看服务器的性能。
        TRACE: 请求服务器在响应中的实体主体部分返回所得到的内容。
        PATCH: 实体中包含一个表,表中说明与该URI所表示的原内容的区别。
        MOVE: 请求服务器将指定的页面移至另一个网络地址。
        COPY: 请求服务器将指定的页面拷贝至另一个网络地址。
        LINK: 请求服务器建立链接关系。
        UNLINK: 断开链接关系。
        WRAPPED: 允许客户端发送经过封装的请求。
        Extension-mothed:在不改动协议的前提下,可增加另外的方法。

请求头:

       Accept:浏览器可接受的MIME类型。
       Accept-Charset:浏览器可接受的 字符集
       Accept-Encoding:浏览器能够进行解码的数据编码方式,比如gzip。Servlet能够向支持gzip的浏览器返回经gzip编码的HTML页面。许多情形下这可以减少5到10倍的下载时间。
       Accept-Language:浏览器所希望的语言种类,当服务器能够提供一种以上的语言版本时要用到。
       Authorization:授权信息,通常出现在对服务器发送的WWW-Authenticate头的应答中。
       Connection:表示是否需要 持久连接。如果Servlet看到这里的值为“Keep-Alive”,或者看到请求使用的是HTTP 1.1(HTTP 1.1默认进行持久连接),它就可以利用持久连接的优点,当页面包含多个元素时(例如Applet,图片),显著地减少下载所需要的时间。要实现这一点,Servlet需要在应答中发送一个Content-Length头,最简单的实现方法是:先把内容写入ByteArrayOutputStream,然后在正式写出内容之前计算它的大小。
       Content-Length:表示请求消息正文的长度。
       Cookie:这是最重要的请求头信息之一
       From:请求发送者的email地址,由一些特殊的Web客户程序使用,浏览器不会用到它。
       Host:初始URL中的 主机和端口。
       If-Modified-Since:只有当所请求的内容在指定的日期之后又经过修改才返回它,否则返回304“Not Modified”应答。
       Pragma:指定“no-cache”值表示服务器必须返回一个刷新后的文档,即使它是 代理服务器而且已经有了页面的本地拷贝。
       Referer:包含一个URL,用户从该URL代表的页面出发访问当前请求的页面。
       User-Agent:浏览器类型,如果Servlet返回的内容与浏览器类型有关则该值非常有用。
       UA-Pixels,UA-Color,UA-OS,UA-CPU:由某些版本的 IE浏览器所发送的非标准的请求头,表示屏幕大小、颜色深度、操作系统和CPU类型。
 

二、响应报文

       包括响应行、响应头和响应数据。具体格式如下:


响应头:

        Allow: 服务器支持哪些请求方法(如GET、POST等)。
          Content-Encoding  文档的编码(Encode)方法。只有在解码之后才可以得到Content-Type头指定的内容类型。利用gzip压缩文档能够显著地减少HTML文档的下载时间。Java的GZIPOutputStream可以很方便地进行gzip压缩,但只有Unix上的Netscape和Windows上的IE 4、IE 5才支持它。因此,Servlet应该通过查看Accept-Encoding头(即request.getHeader("Accept-Encoding"))检查浏览器是否支持gzip,为支持gzip的浏览器返回经gzip压缩的HTML页面,为其他浏览器返回普通页面。
          Content-Length  表示内容长度。只有当浏览器使用持久HTTP连接时才需要这个数据。如果你想要利用 持久连接 的优势,可以把输出文档写入ByteArrayOutputStram,完成后查看其大小,然后把该值放入Content-Length头,最后通过byteArrayStream.writeTo(response.getOutputStream()发送内容。
          Content-Type  表示后面的文档属于什么MIME类型。Servlet默认为text/plain,但通常需要显式地指定为text/html。由于经常要设置Content-Type,因此HttpServletResponse提供了一个专用的方法setContentType。
          Date  当前的GMT时间。你可以用setDateHeader来设置这个头以避免转换时间格式的麻烦。
          Expires  应该在什么时候认为文档已经过期,从而不再缓存它?
          Last-Modified  文档的最后改动时间。客户可以通过If-Modified-Since请求头提供一个日期,该请求将被视为一个条件GET,只有改动时间迟于指定时间的文档才会返回,否则返回一个304(Not Modified)状态。Last-Modified也可用setDateHeader方法来设置。
          Location  表示客户应当到哪里去提取文档。Location通常不是直接设置的,而是通过HttpServletResponse的sendRedirect方法,该方法同时设置 状态代码 为302。
          Refresh表示浏览器应该在多少时间之后刷新文档,以秒计。除了刷新当前文档之外,你还可以通过setHeader("Refresh", "5; URL=http://host/path")让浏览器读取指定的页面。注意这种功能通常是通过设置HTML页面HEAD区的<META HTTP-EQUIV="Refresh" CONTENT="5;URL=http://host/path">实现,这是因为,自动刷新或重定向对于那些不能使用CGI或Servlet的HTML编写者十分重要。但是,对于Servlet来说,直接设置Refresh头更加方便。注意Refresh的意义是“N秒之后刷新本页面或访问指定页面”,而不是“每隔N秒刷新本页面或访问指定页面”。因此,连续刷新要求每次都发送一个Refresh头,而发送204状态代码则可以阻止浏览器继续刷新,不管是使用Refresh头还是<META HTTP-EQUIV="Refresh" ...>。注意Refresh头不属于HTTP 1.1正式规范的一部分,而是一个扩展,但Netscape和IE都支持它。
          Server  服务器名字。Servlet一般不设置这个值,而是由Web服务器自己设置。
          Set-Cookie  设置和页面关联的Cookie。Servlet不应使用response.setHeader("Set-Cookie", ...),而是应使用HttpServletResponse提供的专用方法addCookie。参见下文有关Cookie设置的讨论。
          WWW-Authenticate  客户应该在Authorization头中提供什么类型的授权信息?在包含401(Unauthorized)状态行的应答中这个头是必需的。例如,response.setHeader("WWW-Authenticate", "BASIC realm=\"executives\"")。注意Servlet一般不进行这方面的处理,而是让Web服务器的专门机制来控制受密码保护页面的访问(例如.htaccess)。

状态码:

① 1xx:表示服务器已接收了客户端请求,客户端可继续发送请求
        100  继续
        101  交换协议


② 1xx:表示服务器已接收了客户端请求,客户端可继续发送请求
        200  OK
        201  已创建
        202  接收
        203  非认证信息
        204  无内容
        205  重置内容
        206  部分内容

        
③ 3xx:表示服务器要求客户端重定向
        300  多路选择
        301  永久转移
        302  暂时转移
        303  参见其它
        304  未修改(Not Modified)
        305  使用代理


④ 4xx:表示客户端的请求有非法内容
        400  错误请求(Bad Request)
        401  未认证
        402  需要付费
        403  禁止(Forbidden)
        404  未找到(Not Found)
        405  方法不允许
        406  不接受
        407  需要代理认证
        408  请求超时
        409  冲突
        410  失败
        411  需要长度
        412  条件失败
        413  请求实体太大
        414  请求URI太长
        415  不支持媒体类型


⑤ 5xx:表示服务器未能正常处理客户端的请求而出现意外错误
        500  服务器内部错误
        501  未实现(Not Implemented)
        502  网关失败
        504  网关超时
        505    HTTP版本不支持


 

猜你喜欢

转载自lixiaohui.iteye.com/blog/2321515