当浏览者访问一个网页时,浏览者的浏览器会向网页所在服务器发出请求。当浏览器接收并显示网页前,此网页所在的服务器会返回一个包含HTTP状态码的信息头(server header)用以响应浏览器的请求。

下面是常见的HTTP状态码:

  • 200 - 请求成功
  • 301 - 资源(网页等)被永久转移到其它URL
  • 404 - 请求的资源(网页等)不存在
  • 500 - 内部服务器错误

HTTP状态码由三个十进制数字组成,第一个十进制数字定义了状态码的类型,后两个数字没有分类的作用。HTTP状态码共分为5种类型:

以下是常见状态码的五中类型及状态码的解释说明:

1、1xx(临时响应),表示信息,服务器收到请求,需要请求者继续执行操作。

  100(继续)——请求者应当继续提出请求。服务器返回此代码表示已收到请求的第一部分,正在等待其余部分

  101(切换协议)——请求者已要求服务器切换协议,服务器已确认并准备切换

2、2xx(成功),表示操作被成功接收并处理

  200(成功)——服务器已成功处理了请求。通常,这表示服务器提供了请求的网页。如果是对您的 robots.txt 文件显示此状态码,则表示 Googlebot 已成功检索到该文件。

  201(已创建)——请求成功并且服务器创建了新的资源

  202(已接受)——服务器已接受请求,但尚未处理

  203(非授权信息)——服务器已成功处理了请求,但返回的信息可能来自另一来源

  204(无内容)——服务器成功处理了请求,但没有返回任何内容

  205(重置内容)——服务器成功处理了请求,但没有返回任何内容。与 204 响应不同,此响应要求请求者重置文档视图(例如,清除表单内容以输入新内容)

  206(部分内容)——服务器成功处理了部分 GET 请求

3、3xx(重定向),需要进一步的操作以完成请求。通常,这些状态码用来重定向。

  300(多种选择)——针对请求,服务器可执行多种操作。服务器可根据请求者 (user agent) 选择一项操作,或提供操作列表供请求者选择

  301(永久移动)——请求的网页已永久移动到新位置。服务器返回此响应(对 GET 或 HEAD 请求的响应)时,会自动将请求者转到新位置。您应使用此代码告诉 Googlebot 某个网页或网站已永久移动到新位置

  302(临时移动)——服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来响应以后的请求。此代码与响应 GET 和 HEAD 请求的 301 代码类似,会自动将请求者转到不同的位置,但您不应使用此代码来告诉 Googlebot 某个网页或网站已经移动,因为 Googlebot 会继续抓取原有位置并编制索引

  303(查看其他位置)——请求者应当对不同的位置使用单独的 GET 请求来检索响应时,服务器返回此代码。对于除 HEAD 之外的所有请求,服务器会自动转到其他位置

  304(未修改)——如果网页自请求者上次请求后再也没有更改过,您应将服务器配置为返回此响应(称为 If-Modified-Since HTTP 标头)。服务器可以告诉 Googlebot 自从上次抓取后网页没有变更,进而节省带宽和开销

  305(使用代理)——请求者只能使用代理访问请求的网页。如果服务器返回此响应,还表示请求者应使用代理

  307(临时重定向)——服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来响应以后的请求。此代码与响应 GET 和 HEAD 请求的 301 代码类似,会自动将请求者转到不同的位置,但您不应使用此代码来告诉 Googlebot 某个页面或网站已经移动,因为 Googlebot 会继续抓取原有位置并编制索引

4、4xx(请求错误),客户端错误,请求包含语法错误或无法完成请求

  400(错误请求)——服务器不理解请求的语法

  401(未授权)——请求要求身份验证。对于登录后请求的网页,服务器可能返回此响应

  403(禁止)——服务器拒绝请求。可能是您的服务器或主机拒绝了访问

  404(未找到)——服务器找不到请求的网页。例如,对于服务器上不存在的网页经常会返回此代码。

  405(方法禁用)——禁用请求中指定的方法

  406(不接受)——无法使用请求的内容特性响应请求的网页

  407(需要代理授权)——此状态码请求要求代理的身份认证,与401类似,但指定请求者应当授权使用代理。如果服务器返回此响应,还表示请求者应当使用代理。

  408(请求超时)——服务器等候请求时发生超时

  409(冲突)——服务器在完成请求时发生冲突。服务器必须在响应中包含有关冲突的信息。服务器在响应与前一个请求相冲突的 PUT 请求时可能会返回此代码,以及两个请求的差异列表

  410(已删除)——如果请求的资源已永久删除,服务器就会返回此响应。该代码与 404(未找到)代码类似,但在资源以前存在而现在不存在的情况下,有时会用来替代 404 代码。如果资源已永久移动,您应使用 301 指定资源的新位置

  411(需要有效长度)——服务器不接受不含有效内容长度标头字段的请求

  412(未满足前提条件)——服务器未满足请求者在请求中设置的其中一个前提条件

  413(请求实体过大)——服务器无法处理请求,因为请求实体过大,超出服务器的处理能力

  414(请求的 URI 过长)——请求的 URI(通常为网址)过长,服务器无法处理

  415(不支持的媒体类型)——请求的格式不受请求页面的支持

  416(请求范围不符合要求)——如果页面无法提供请求的范围,则服务器会返回此状态码

  417(未满足期望值)——服务器未满足”期望”请求标头字段的要求

5、5xx(服务器错误),这些状态码表示服务器在处理请求时发生内部错误。这些错误可能是服务器本身的错误,而不是请求出错

  500(服务器内部错误)——服务器遇到错误,无法完成请求

  501(尚未实施)——服务器不具备完成请求的功能。例如,服务器无法识别请求方法时可能会返回此代码

  502(错误网关)——服务器作为网关或代理,从上游服务器收到无效响应

  503(服务不可用)——服务器目前无法使用(由于超载或停机维护)。通常,这只是暂时状态

  504(网关超时)——服务器作为网关或代理,但是没有及时从上游服务器收到请求

  505(HTTP 版本不受支持)——服务器不支持请求中所用的 HTTP 协议版本

参考文件:

http://www.runoob.com/http/http-status-codes.html

http://blog.csdn.net/piaoxuan1987/article/details/51603671

http状态码学习笔记的更多相关文章

  1. Underscore.js 源码学习笔记(下)

    上接 Underscore.js 源码学习笔记(上) === 756 行开始 函数部分. var executeBound = function(sourceFunc, boundFunc, cont ...

  2. Hadoop源码学习笔记(6)——从ls命令一路解剖

    Hadoop源码学习笔记(6) ——从ls命令一路解剖 Hadoop几个模块的程序我们大致有了点了解,现在我们得细看一下这个程序是如何处理命令的. 我们就从原头开始,然后一步步追查. 我们先选中ls命 ...

  3. Hadoop源码学习笔记(4) ——Socket到RPC调用

    Hadoop源码学习笔记(4) ——Socket到RPC调用 Hadoop是一个分布式程序,分布在多台机器上运行,事必会涉及到网络编程.那这里如何让网络编程变得简单.透明的呢? 网络编程中,首先我们要 ...

  4. RocketMQ 源码学习笔记————Producer 是怎么将消息发送至 Broker 的?

    目录 RocketMQ 源码学习笔记----Producer 是怎么将消息发送至 Broker 的? 前言 项目结构 rocketmq-client 模块 DefaultMQProducerTest ...

  5. RocketMQ 源码学习笔记 Producer 是怎么将消息发送至 Broker 的?

    目录 RocketMQ 源码学习笔记 Producer 是怎么将消息发送至 Broker 的? 前言 项目结构 rocketmq-client 模块 DefaultMQProducerTest Roc ...

  6. Qt Creator 源码学习笔记04,多插件实现原理分析

    阅读本文大概需要 8 分钟 插件听上去很高大上,实际上就是一个个动态库,动态库在不同平台下后缀名不一样,比如在 Windows下以.dll结尾,Linux 下以.so结尾 开发插件其实就是开发一个动态 ...

  7. JUC源码学习笔记2——AQS共享和Semaphore,CountDownLatch

    本文主要讲述AQS的共享模式,共享和独占具有类似的套路,所以如果你不清楚AQS的独占的话,可以看我的<JUC源码学习笔记1> 主要参考内容有<Java并发编程的艺术>,< ...

  8. JUC源码学习笔记5——线程池,FutureTask,Executor框架源码解析

    JUC源码学习笔记5--线程池,FutureTask,Executor框架源码解析 源码基于JDK8 参考了美团技术博客 https://tech.meituan.com/2020/04/02/jav ...

  9. Spring 源码学习笔记11——Spring事务

    Spring 源码学习笔记11--Spring事务 Spring事务是基于Spring Aop的扩展 AOP的知识参见<Spring 源码学习笔记10--Spring AOP> 图片参考了 ...

随机推荐

  1. ETL利器Kettle实战应用解析系列二

    本系列文章主要索引如下: 一.ETL利器Kettle实战应用解析系列一[Kettle使用介绍] 二.ETL利器Kettle实战应用解析系列二 [应用场景和实战DEMO下载] 三.ETL利器Kettle ...

  2. Nagios Openstack Plugin

    Some simple example for checking Openstack services check nova service list #!/bin/sh export OS_PROJ ...

  3. 002_安装第三方APP好的站点及解除安全与隐私限制

    一.解除安全与隐私限制的任何来源. http://bbs.feng.com/read-htm-tid-10714286.html 接下来,我们就打开终端,然后输入以下命令:   sudo spctl ...

  4. redis从入门到放弃 -> 简介&概念

    一.redis简介 Redis是一款开源的.高性能的键-值存储.它常被称作是一款数据结构服务器. 当值支持的主要数据类型为:字符串(strings)类型,括哈希(hashes).列表(lists).集 ...

  5. Android页面之间进行数据回传

    要求:页面1跳转到页面2,页面2再返回页面1同时返回数据 页面1添加如下代码: Intent intent = new Intent(); intent.setClass(页面1.this, 页面2. ...

  6. ARKit从入门到精通

    ARKit从入门到精通(10)-ARKit让飞机绕着你飞起来 ARKit从入门到精通(9)-ARKit让飞机跟着镜头飞起来 ARKit从入门到精通(8)-ARKit捕捉平地 ARKit从入门到精通(7 ...

  7. sem_open中信号量命名

    问题: sem_open will failed with "No such file or directory"   解释1: 这是由于在Linux内核中,创建信号量的默认路径是 ...

  8. (转)链接服务器——获取EXCEL数据

    测试目的:验证利用链接服务器.分布式查询获取EXCEL中的数据测试环境:Microsoft SQL Server 2005 - 9.00.3080.00 (X64)  Enterprise Editi ...

  9. Linux下的堆off-by-one的利用

    这篇稿子已经投到了360安全播报,http://bobao.360.cn/learning/detail/3113.html

  10. oplog扩容

    Oplog的扩容: 背景:一个由3个节点组成的复制集. 主节点:A 从节点:B,C 需求:Oplog扩容,尽量少的影响业务. 思路:先由从节点开始,一台一台的从复制集中剥离,修改,再回归复制集,最后操 ...