`

状态代码

 
阅读更多
7 状态代码

   7.1 状态代码概述

  Web服务器响应浏览器或其他客户程序的请求时,其应答一般由以下几个部分组成:一个状态行,几个应答头,一个空行,内容文档。下面是一个最简单的应答:

HTTP/1.1 200 OK
Content-Type: text/plain

Hello World

  状态行包含HTTP版本、状态代码、与状态代码对应的简短说明信息。在大多数情况下,除了Content-Type之外的所有应答头都是可选的。但Content-Type是必需的,它描述的是后面文档的MIME类型。虽然大多数应答都包含一个文档,但也有一些不包含,例如对HEAD请求的应答永远不会附带文档。有许多状态代码实际上用来标识一次失败的请求,这些应答也不包含文档(或只包含一个简短的错误信息说明)。

  Servlet可以利用状态代码来实现许多功能。例如,可以把用户重定向到另一个网站;可以指示出后面的文档是图片、PDF文件或HTML文件;可以告诉用户必须提供密码才能访问文档;等等。这一部分我们将具体讨论各种状态代码的含义以及利用这些代码可以做些什么。

  7.2 设置状态代码

  如前所述,HTTP应答状态行包含HTTP版本、状态代码和对应的状态信息。由于状态信息直接和状态代码相关,而HTTP版本又由服务器确定,因此需要Servlet设置的只有一个状态代码。

  Servlet设置状态代码一般使用HttpServletResponse的setStatus方法。setStatus方法的参数是一个整数(即状态代码),不过为了使得代码具有更好的可读性,可以用HttpServletResponse中定义的常量来避免直接使用整数。这些常量根据HTTP 1.1中的标准状态信息命名,所有的名字都加上了SC前缀(Status Code的缩写)并大写,同时把空格转换成了下划线。也就是说,与状态代码404对应的状态信息是“Not Found”,则HttpServletResponse中的对应常量名字为SC_NOT_FOUND。但有两个例外:和状态代码302对应的常量根据HTTP 1.0命名,而307没有对应的常量。

  设置状态代码并非总是意味着不要再返回文档。例如,虽然大多数服务器返回404应答时会输出简单的“File Not Found”信息,但Servlet也可以定制这个应答。不过,定制应答时应当在通过PrintWriter发送任何内容之前先调用response.setStatus。

  虽然设置状态代码一般使用的是response.setStauts(int)方法,但为了简单起见,HttpServletResponse为两种??那樾翁峁┝俗ㄓ梅椒ǎ?endError方法生成一个404应答,同时生成一个简短的HTML错误信息文档;sendRedirect方法生成一个302应答,同时在Location头中指示新文档的URL。

  7.3 HTTP 1.1状态代码及其含义

  下表显示了???TTP 1.1状态代码以及它们对应的状态信息和含义。

  应当谨慎地使用那些只有HTTP 1.1支持的状态代码,因为许多浏览器还只能够支持HTTP 1.0。如果你使用了HTTP 1.1特有的状态代码,最好能够检查一下请求的HTTP版本号(通过HttpServletRequest的getProtocol方法)。

状态代码 状态信息 含义
100 Continue 初始的请求已经接受,客户应当继续发送请求的其余部分。(HTTP 1.1新)
101 Switching Protocols 服务器将遵从客户的请求转换到另外一种协议(HTTP 1.1新)
200 OK 一切正常,对GET和POST请求的应答文档跟在后面。如果不用setStatus设置状态代码,Servlet默认使用202状态代码。
201 Created 服务器已经创建了文档,Location头给出了它的URL。
202 Accepted 已经接受请求,但处理尚未完成。
203 Non-Authoritative Information 文档已经正常地返回,但一些应答头可能不正确,因为使用的是文档的拷贝(HTTP 1.1新)。
204 No Content 没有新文档,浏览器应该继续显示原来的文档。如果用户定期地刷新页面,而Servlet可以确定用户文档足够新,这个状态代码是很有用的。
205 Reset Content 没有新的内容,但浏览器应该重置它所显示的内容。用来强制浏览器清除表单输入内容(HTTP 1.1新)。
206 Partial Content 客户发送了一个带有Range头的GET请求,服务器完成了它(HTTP 1.1新)。
300 Multiple Choices 客户请求的文档可以在多个位置找到,这些位置已经在返回的文档内列出。如果服务器要提出优先选择,则应该在Location应答头指明。
301 Moved Permanently 客户请求的文档在其他地方,新的URL在Location头中给出,浏览器应该自动地访问新的URL。
302 Found 类似于301,但新的URL应该被视为临时性的替代,而不是永久性的。注意,在HTTP1.0中对应的状态信息是“Moved Temporatily”,而HttpServletResponse中相应的常量是SC_MOVED_TEMPORARILY,而不是SC_FOUND。
出现该状态代码时,浏览器能够自动访问新的URL,因此它是一个很有用的状态代码。为此,Servlet提供了一个专用的方法,即sendRedirect。使用response.sendRedirect(url)比使用response.setStatus(response.SC_MOVED_TEMPORARILY)和response.setHeader("Location",url)更好。这是因为:

首先,代码更加简洁。
第二,使用sendRedirect,Servlet会自动构造一个包含新链接的页面(用于那些不能自动重定向的老式浏览器)。
最后,sendRedirect能够处理相对URL,自动把它们转换成绝对URL。
注意这个状态代码有时候可以和301替换使用。例如,如果浏览器错误地请求http://host/~user(缺少了后面的斜杠),有的服务器返回301,有的则返回302。

严格地说,我们只能假定只有当原来的请求是GET时浏览器才会自动重定向。请参见307。
303 See Other 类似于301/302,不同之处在于,如果原来的请求是POST,Location头指定的重定向目标文档应该通过GET提取(HTTP 1.1新)。
304 Not Modified 客户端有缓冲的文档并发出了一个条件性的请求(一般是提供If-Modified-Since头表示客户只想比指定日期更新的文档)。服务器告诉客户,原来缓冲的文档还可以继续使用。
305 Use Proxy 客户请求的文档应该通过Location头所指明的代理服务器提取(HTTP 1.1新)。
307 Temporary Redirect 和302(Found)相同 。许多浏览器会错误地响应302应答进行重定向,即使原来的请求是POST,即使它实际上只能在POST请求的应答是303时才能重定向。由于这个原因,HTTP 1.1新增了307,以便更加清除地区分几个状态代码:当出现303应答时,浏览器可以跟随重定向的GET和POST请求;如果是307应答,则浏览器只能跟随对GET请求的重定向。 注意,HttpServletResponse中没有为该状态代码提供相应的常量。(HTTP 1.1新)
400 Bad Request 请求出现语法错误。
401 Unauthorized 客户试图未经授权访问受密码保护的页面。应答中会包含一个WWW-Authenticate头,浏览器据此显示用户名字/密码对话框,然后在填写合适的Authorization头后再次发出请求。
403 Forbidden 资源不可用。服务器理解客户的请求,但拒绝处理它。通常由于服务器上文件或目录的权限设置导致。
404 Not Found 无法找到指定位置的资源。这也是一个常用的应答,HttpServletResponse专门提供了相应的方法:sendError(message)。
405 Method Not Allowed 请求方法(GET、POST、HEAD、DELETE、PUT、TRACE等)对指定的资源不适用。(HTTP 1.1新)
406 Not Acceptable 指定的资源已经找到,但它的MIME类型和客户在Accpet头中所指定的不兼容(HTTP 1.1新)。
407 Proxy Authentication Required 类似于401,表示客户必须先经过代理服务器的授权。(HTTP 1.1新)
408 Request Timeout 在服务器许可的等待时间内,客户一直没有发出任何请求。客户可以在以后重复同一请求。(HTTP 1.1新)
409 Conflict 通常和PUT请求有关。由于请求和资源的当前状态相冲突,因此请求不能成功。(HTTP 1.1新)
410 Gone 所请求的文档已经不再可用,而且服务器不知道应该重定向到哪一个地址。它和404的不同在于,返回407表示文档永久地离开了指定的位置,而404表示由于未知的原因文档不可用。(HTTP 1.1新)
411 Length Required 服务器不能处理请求,除非客户发送一个Content-Length头。(HTTP 1.1新)
412 Precondition Failed 请求头中指定的一些前提条件失败(HTTP 1.1新)。
413 Request Entity Too Large 目标文档的大小超过服务器当前愿意处理的大小。如果服务器认为自己能够稍后再处理该请求,则应该提供一个Retry-After头(HTTP 1.1新)。
414 Request URI Too Long URI太长(HTTP 1.1新)。
416 Requested Range Not Satisfiable 服务器不能满足客户在请求中指定的Range头。(HTTP 1.1新)
500 Internal Server Error 服务器遇到了意料不到的情况,不能完成客户的请求。
501 Not Implemented 服务器不支持实现请求所需要的功能。例如,客户发出了一个服务器不支持的PUT请求。
502 Bad Gateway 服务器作为网关或者代理时,为了完成请求访问下一个服务器,但该服务器返回了非法的应答。
503 Service Unavailable 服务器由于维护或者负载过重未能应答。例如,Servlet可能在数据库连接池已满的情况下返回503。服务器返回503时可以提供一个Retry-After头。
504 Gateway Timeout 由作为代理或网关的服务器使用,表示不能及时地从远程服务器获得应答。(HTTP 1.1新)
505 HTTP Version Not Supported 服务器不支持请求中所指明的HTTP版本。(HTTP 1.1新)

  7.4 实例:访问多个搜索引擎

  下面这个例子用到了除200之外的另外两个??刺??耄?02和404。302通过sendRedirect方法设置,404通过sendError方法设置。

  在这个例子中,首先出现的HTML表单用来选择搜索引擎、搜索字符串、每页显示的搜索结果数量。表单提交后,Servlet提取这三个变量,按照所选择的搜索引擎的要求构造出包含这些变量的URL,然后把用户重定向到这个URL。如果用户不能正确地选择搜索引擎,或者利用其他表单发送了一个不认识的搜索引擎名字,则返回一个提示搜索引擎找不到的404页面。

  SearchEngines.java

  注意:这个Servlet要用到后面给出的SearchSpec类,SearchSpec的功能是构造适合不同搜索引擎的URL。
package com.mcbeath.life.user.action;

import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.net.*;

public class SearchEngines extends HttpServlet {
  public void doGet(HttpServletRequest request, HttpServletResponse response) 
         throws ServletException, IOException { 
      // getParameter自动解码URL编码的查询字符串。由于我们 
      // 要把查询字符串发送给另一个服务器,因此再次使用 
      // URLEncoder进行URL编码 
      String searchString =URLEncoder.encode(request.getParameter("searchString")); 
      String numResults =request.getParameter("numResults"); 
      String searchEngine =request.getParameter("searchEngine"); 
      SearchSpec[] commonSpecs = SearchSpec.getCommonSpecs(); 
      for(int i=0; i<commonSpecs.length; i++) { 
         SearchSpec searchSpec = commonSpecs[i]; 
          if (searchSpec.getName().equals(searchEngine)) { 
            String url =response.encodeURL(searchSpec.makeURL(searchString,numResults)); 
            response.sendRedirect(url); 
           return; 
         } 
       } 
       response.sendError(response.SC_NOT_FOUND,"No recognized search engine specified.");
}

  public void doPost(HttpServletRequest request, 
      HttpServletResponse response) 
      throws ServletException, IOException { 
       this.doGet(request, response); 
   }
}

SearchSpec.java
package com.mcbeath.life.user.action;

public class SearchSpec {
  private String name;
  private String baseURL;
  private String numResultsSuffix;

  private static SearchSpec[] commonSpecs = { new SearchSpec("google", "http://www.google.com/search?q=", "&num="),
      new SearchSpec("infoseek", "http://infoseek.go.com/Titles?qt=", "&nh="),
      new SearchSpec("lycos", "http://lycospro.lycos.com/cgi-bin/pursuit?query=", "&maxhits="),
      new SearchSpec("hotbot", "http://www.hotbot.com/?MT=", "&DC=") };

  public SearchSpec(String name, String baseURL, String numResultsSuffix) {
    this.name = name;
    this.baseURL = baseURL;
    this.numResultsSuffix = numResultsSuffix;
  }

  public String makeURL(String searchString, String numResults) {
    return (baseURL + searchString + numResultsSuffix + numResults);
  }

  public String getName() {
    return name;
  }

  public static SearchSpec[] getCommonSpecs() {
    return commonSpecs;
  }
}

SearchEngines.html

  下面是调用上述Servlet的HTML表单。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> 
<HTML> 
<HEAD> 
<TITLE>访问多个搜索引擎</TITLE> 
</HEAD> 

<BODY BGCOLOR="#FDF5E6"> 

<FORM ACTION="/servlet/hall.SearchEngines"> 
<CENTER> 
搜索关键字: 
<INPUT TYPE="TEXT" NAME="searchString"><BR> 
每页显示几个查询结果: 
<INPUT TYPE="TEXT" NAME="numResults" 
VALUE=10 SIZE=3><BR> 
<INPUT TYPE="RADIO" NAME="searchEngine" 
VALUE="google"> 
Google | 
<INPUT TYPE="RADIO" NAME="searchEngine" 
VALUE="infoseek"> 
Infoseek | 
<INPUT TYPE="RADIO" NAME="searchEngine" 
VALUE="lycos"> 
Lycos | 
<INPUT TYPE="RADIO" NAME="searchEngine" 
VALUE="hotbot"> 
HotBot 
<BR> 
<INPUT TYPE="SUBMIT" VALUE="Search"> 
</CENTER> 
</FORM> 

</BODY> 
</HTML> 
分享到:
评论

相关推荐

    HTTP状态码及其含义 下表显示了常见的HTTP 1.1状态代码以及它们对应的状态信息和含义。

    状态代码 状态信息 含义 100 Continue 初始的请求已经接受,客户应当继续发送请求的其余部分。(HTTP 1.1新) 101 Switching Protocols 服务器将遵从客户的请求转换到另外一种协议(HTTP 1.1新) 200 OK 一切正常...

    HTTP状态代码列表

    HTTP状态代码列表,很全,还有很详细的解释

    HTTP服务器状态代码定义

    1. 信息性状态代码(1xx): 这些代码是临时性的,主要用于通知客户端服务器正在处理请求,但还没有完成。例如,100 Continue 表示服务器已接收请求头,客户端应继续发送请求主体。 2. 成功状态代码(2xx): 这...

    浮动QQ 阿里旺旺 skype在线状态代码

    浮动QQ 阿里旺旺 skype在线状态代码

    HTTP状态代码

    HTTP状态代码

    HTTP 状态代码及其定义

    6. 特殊状态代码:除了标准的三位数状态代码,还有一些非官方或者预留的状态代码,如418(我是茶壶)是一个愚人节玩笑,520(Web服务器扩展错误)可能是某些云服务提供商自定义的状态代码。 了解并掌握HTTP状态代码...

    QQ在线状态代码生成器

    QQ在线状态代码生成器是一种工具,它允许用户生成特定的代码,这些代码可以用来显示他们的QQ在线状态。在互联网和即时通讯的世界里,状态代码是一个关键元素,它能够告诉其他用户你当前的在线状态,例如“在线”、...

    http错误代码含义这些状态代码表示临时的响应。客户端在收到常规响应之前,应准备接收一个或多个 1xx 响应。

    http错误代码含义这些状态代码表示临时的响应。客户端在收到常规响应之前,应准备接收一个或多个 1xx 响应。

    HTTP 状态代码及其含义

    HTTP(超文本传输协议)是互联网上应用最广泛的一种网络协议,用于从万维网服务器传输超文本到本地浏览器的传输协议。...在开发过程中,熟练掌握各种状态代码的含义,可以提高工作效率,确保服务的稳定性和可靠性。

    HTTP 状态代码解释

    1xx(临时响应)状态代码,如100(继续)和101(切换协议),表明服务器已经接收到部分请求,并且客户端需要继续发送请求的剩余部分,或者服务器准备切换到另一个协议,如从HTTP切换到HTTPS。 2xx(成功)状态代码...

    http 状态代码大全

    http 状态代码大全 http 状态代码大全

    所有HTTP状态代码及其定义.doc

    1xx - 信息提示:这些状态代码是临时响应,表明服务器已经接收到部分请求,客户端需要继续处理。例如,100 - 继续表示服务器接收了请求头,等待客户端发送更多数据;101 - 切换协议则表示服务器将改变通信协议。 2...

    loadrunnerHTTP服务器状态代码定义[参考].pdf

    1. 1xx(Informational 1xx)状态代码: 这类代码是临时响应,表明服务器已接收请求但未完成处理。例如,100 Continue 表示服务器已接收到请求头,客户端应继续发送请求体。 2. 2xx(Successful 2xx)状态代码: 这...

    http状态代码(错误代码)各代表什么意思.docx

    1xx(临时响应):这类状态代码表示服务器已经接收到部分请求,需要客户端继续进行操作。例如,100(继续)表明服务器收到了请求的一部分,等待接收剩余内容;101(切换协议)意味着服务器同意切换到客户端请求的...

    Python-statcode与man手册页一样但是对于HTTP状态代码说明

    在Python的网络编程领域,了解HTTP状态代码是至关重要的,因为它们是Web服务器与客户端通信时用来表示请求处理结果的标准化数字代码。标题提到的"Python-statcode"库,就是为了帮助开发者更方便地理解和处理这些状态...

    web状态代码表.xls

    状态代码表.xls 一起分享!!! 状态代码表.xls 一起分享!!! 状态代码表.xls 一起分享!!!

    QQ、淘宝、MSN、Skype在线状态代码生成方法

    QQ、淘宝、MSN、Skype在线状态代码生成方法 QQ、淘宝、MSN、Skype在线状态代码生成方法

    IIS状态代码的含义

    当用户试图通过HTTP或文件传输协议(FTP)访问一台正在运行Internet信息服务...该状态代码记录在IIS日志中,同时也可能在Web浏览器或FTP客户端显示。状态代码可以指明具体请求是否已成功,还可以揭示请求失败的确切原因。

    网易短信接口状态代码

    网易短信接口状态代码,依据网易云的短信接口返回的状态查看失败等信息

    java状态代码说明

    java状态代码说明

Global site tag (gtag.js) - Google Analytics