当用户试图通过 HTTP 或文件传输协议 (FTP) 访问一台正在运行 Internet 信息服务 (IIS) 的服务器上的内容时,IIS 返回一个表示该请求的状态的数字代码。该状态代码记录在 IIS 日志中,同时也可能在 Web 浏览器或 FTP 客户端显示。状态代码可以指明具体请求是否已成功,还可以揭示请求失败的确切原因。 日志文件的位置。在默认状态下,IIS 把它的日志文件放在 %WINDIR\System32\Logfiles 文件夹中。每个万维网 (WWW) 站点和 FTP 站点在该目录下都有一个单独的目录。在默认状态下,每天都会在这些目录下创建日志文件,并用日期给日志文件命名(例如,exYYMMDD.log)。 1. 信息提示 -1xx 这些状态代码表示临时的响应。客户端在收到常规响应之前,应准备接收一个或多个 1xx 响应。 100 Continue 初始的请求已经接受,客户应当继续发送请求的其余部分。 101 Switching Protocols 服务器将遵从客户的请求切换到另外一种协议。 2. 成功 -2xx 这类状态代码表明服务器成功地接受了客户端请求。 200 OK 一切正常,对 GET 和 POST 请求的应答文档跟在后面。 201 Created 服务器已经创建了文档,Location 头给出了它的 URL. 202 Accepted 已经接受请求,但处理尚未完成。 203 Non-Authoritative Information 文档已经正常地返回,但一些应答头可能不正确,因为使用的是文档的拷贝。 204 No Content 没有新文档,浏览器应该继续显示原来的文档。如果用户定期地刷新页面,而 Servlet 可以确定用户文档足够新,这个状态代码是很有用的。 205 Reset Content 没有新的内容,但浏览器应该重置它所显示的内容。用来强制浏览器清除表单输入内容 206 Partial Content 客户发送了一个带有 Range 头的 GET 请求,服务器完成了它。 3. 重定向 -3xx 客户端浏览器必须采取更多操作来实现请求。例如,浏览器可能不得不请求服务器上的不同的页面,或通过代理服务器重复该请求。 300 Multiple Choices 客户请求的文档可以在多个位置找到,这些位置已经在返回的文档内列出。如果服务器要提出优先选择,则应该在 Location 应答头指明。 301 Moved Permanently 客户请求的文档在其他地方,新的 URL 在 Location 头中给出,浏览器应该自动地访问新的 URL. 302 Found 类似于 301,但新的 URL 应该被视为临时性的替代,而不是永久性的。注意,在 HTTP1.0 中对应的状态信息是"Moved Temporatily",出现该状态代码时,浏览器能够自动访问新的 URL,因此它是一个很有用的状态代码。注意这个状态代码有时候可以和 301 替换使用。例如,如果浏览器错误地请求,有的服务器返回 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 请求的重定向。 4. 客户端错误 -4xx 发生错误,客户端似乎有问题。例如,客户端请求不存在的页面,客户端未提供有效的身份验证信息。 400 Bad Request 请求出现语法错误。 401 Unauthorized 客户试图未经授权访问受密码保护的页面。应答中会包含一个 WWW-Authenticate 头,浏览器据此显示用户名字 / 密码对话框,然后在填写合适的 Authorization 头后再次发出请求。IIS 定义了许多不同的 401 错误,它们指明更为具体的错误原因。这些具体的错误代码在浏览器中显示,但不在 IIS 日志中显示: 401.1- 登录失败。401.2- 服务器配置导致登录失败。401.3- 由于 ACL 对资源的限制而未获得授权。401.4- 筛选器授权失败。401.5-ISAPI/CGI 应用程序授权失败。401.7–访问被 Web 服务器上的 URL 授权策略拒绝。这个错误代码为 IIS 6.0 所专用。 403 Forbidden 资源不可用。服务器理解客户的请求,但拒绝处理它。通常由于服务器上文件或目录的权限设置导致。 IIS 定义了许多不同的 403 错误,它们指明更为具体的错误原因: 403.1- 执行访问被禁止。403.2- 读访问被禁止。403.3- 写访问被禁止。403.4- 要求 SSL.403.5- 要求 SSL 128.403.6-IP 地址被拒绝。403.7- 要求客户端证书。403.8- 站点访问被拒绝。403.9- 用户数过多。403.10- 配置无效。403.11- 密码更改。403.12- 拒绝访问映射表。403.13- 客户端证书被吊销。403.14- 拒绝目录列表。403.15- 超出客户端访问许可。403.16- 客户端证书不受信任或无效。403.17- 客户端证书已过期或尚未生效。403.18- 在当前的应用程序池中不能执行所请求的 URL.这个错误代码为 IIS 6.0 所专用。403.19- 不能为这个应用程序池中的客户端执行 CGI.这个错误代码为 IIS 6.0 所专用。403.20-Passport 登录失败。这个错误代码为 IIS 6.0 所专用。 404 Not Found 无法找到指定位置的资源。这也是一个常用的应答。 404.0-(无)–没有找到文件或目录。404.1- 无法在所请求的端口上访问 Web 站点。404.2-Web 服务扩展锁定策略阻止本请求。404.3-MIME 映射策略阻止本请求。 405 Method Not Allowed 请求方法(GET、POST、HEAD、DELETE、PUT、TRACE 等)对指定的资源不适用。 406…