HTTP的介绍以及状态码全面总结

一、面向连接和无连接协议(Connection-OrientedandConnectionlessProtocols)

1、面向连接服务的主要特点有:面向连接服务要经过三个阶段:数据传数前,先建立连接,连接建立后再传输数据,数据传送完后,释放连接。面向连接服务,可确保数据传送的次序和传输的可靠性。

2、无连接服务的特点是:无连接服务只有传输数据阶段。消除了除数据通信外的其它开销。只要发送实体是活跃的,无须接收实体也是活跃的。它的优点是灵活方便、迅速,特别适合于传送少量零星的报文,但无连接服务不能防止报文的丢失、重复或失序。 

举个例子:打电话就是面向连接的,手机发送短信就是无连接的。

二、Http介绍

1、Http是面向连接的服务。Http从客户端到服务端的请求都要经过4个步骤:
       A:打开端口建立一个TCP连接,默认是80端口
       B:客户端向服务器发送消息,请求指定路径上的资源,这个请求包括一个首部,可选地还可以有一个空行,后面是请求的资源
       C:服务器向客户端发送响应。响应以响应码开头,后面包含元数据的首部,一个空行以及所请求的文档或错误信息。
       D:服务器关闭连接。
2、HTTP请求头中的Key:Value解析。
     *User-Agent:Lynx/2.4 libwww/2.1.4
      这就是我们经常说的UA,他的Value值一般都是指定的是哪个平台,以及浏览器的版本
     *Host: www.cafeaulait.org
       用来指定服务器的域名
     *Accept:text/html,application/xhtml+xml,application/xml
       Accept告诉服务器客户端可以处理哪些MIME数据类型
               如以下客户端可以处理4中MIME媒体类型
               Accept: text/html,text/plain,image/gif,image/jpeg
       这四种类型分别指的是HTML文档,纯文本,GIF图片和JPEG图片
               MIME类型分为两级:类型(type)/子类型(subtype) text/html 其中text是类型,html是子类型
               在HTTP中一共有八个顶级类型:
                   text/* 表示可读入的文字
                   image/* 表示图片
                   mode/*  表示3D模型,如CRML文件
                   audio/*   表示声音
                   video/*    表示移动的图片,可能包括声音
                   application/* 表示二进制数据
                   message/* 表示协议特定的信封
                   multipart/* 表示文档和资源的容器,我们上传文件都用这个类型。
              *Connection:Keep-Alive
                连接重用,HTTP1.0 会为每个请求打开一个新连接,一个典型Web会话中打开和关闭所有连接所花费的时间远远大于实际传输数据的时间,特别是有很多小的文档的会话(我们的Json,xml都是文档),对于使用SSL或TLS加密的HTTPS请求,问题会更加严重,因为建立一个安全socket的握手过程比建立常规的socket需要做更多的工作。
HTTP1.1之后,服务器不必在发送响应后就关闭连接。(在HTTP1.0的时候response中会有Connection:close),这样可以保持连接,可以在一个TCP连接上连续发送多个请求和响应,不过服务器响应之后,客户端请求的锁步模式还是一样的。
       *Content-type:application/x-www-form-urlencoded
                指定类型的MIME媒体类型,我们上传的Webfrom数据都是基于这个类型,我们还有的用application/json这个可以传json实体,还有multipart/form-data,用来传输文件流。multipart/form-data也可以传输application/x-www-form-urlencoded传输的类型。那么为啥不直接用multipart/form-data,我了解的原因有两个:
              第一个:"multipart/form-data"情况下因为增加了分隔线boundary以及Content-Disposition等内容,请求的内容可能会稍比 “application/x-www-form-urlencoded”要多
      第二个:使用multipart/form-data最后数据会以二进制形式提交给服务器,字符不需要编码不会对服务端的获取有影响。
               *Content-length:54
               指定主体内有多少个字节
*Cookie
                很多网站用一些小文本串在连接之间存储持久的客户端状态,这些小文本串称为cookie。cookie在请求和响应的HTTP首部,从服务器传递到客户端,再从客户端传回服务器。Cookie只能是非空白符的ASCII文本,不能包含逗号或分号。
               服务器返回时设置cookie
Cookie:cart=ssss
客户端再次请求的时候会带着这个Cookie
                Set-Cookie:cookie1
Set-Cookie:cookie2
                所以客户端在请求的时候可以设置多个cookie

三、HTTP--response status code状态码解析

      
响应码和消息含义
1XX1开头的表示的是信息
100-Continue服务器准备接受请求主体,客户端应当发送请求主体,这允许客户端在请求中发送大量数据之前询问服务器是否将接受请求
101 Switching服务器接受客户端在Upgrade首部字段中要求改变应用协议的请求,如从HTTP改为WebSocket
2XX Successful2开头的表示请求成功
200 OKGET或POST方法返回的响应码
201 Created服务器已经在响应主体中指定的URL处创建了资源。客户端现在应当尝试加载改URL。这个响应码只在响应POST请求时发送
202 Accepted这是个很不常见的响应,表示请求(一般是POST)已经被处理,但处理尚未结束,所以不会返回任何响应。不过,服务器应当为用户返回一个HTML页面解释这个情况,并估计请求何时能够结束,理想情况下要提供某种状态监视器的链接。
203 Nonauthoritative information由缓存代理或其他本地源返回资源的表示,不能保证是最新的
204 No Content服务器已经成功地处理了请求,但没有信息发回给客户端。这一般是由于服务器上的表单处理程序编写的很差,只接受数据却不向用户返回响应
205 Reset Content服务器已经成功地处理了请求,但没有信息发回给客户端。。此外,客户端应当清除发送请求的表单
206 Partial Content服务器返回客户端请求的资源的一部分,而不是整个文档
226 IM Used响应得到deIta编码
3XX Redirection3开头的表示重定位及重定向
300 Multiple Choices服务器为所请求的文档提供一组不同的表示
301 Moved Permanently资源已经移动到一个新的URL。客户端应当自动加载这个URL的资源,更新所有指向原URL的书签
302 Moved Temporarily这个资源暂时位于一个新的URL,但其位置在不久的将来还会再次改变,所以不应当更新书签。有时有些代理要求用户在访问Web之前先在本地登录,此时会用到这个响应码
303 See Other一般用于响应POST表单请求,这个响应码表示用户应当使用GET从另一个不同的URL获取资源
304 Not ModifiedIf-Modified-Since首部指示客户端只需要最近更新的文档。如果文档没有更新,就会返回这个状态码。在这种情况下,客户端应当从缓存中加载这个文档。
305 Use ProxyLocation首部字段包含将提供响应的代理的地址
307 Temporary Redirect类似于响应码302,但不允许HTTP方法改变
308 Permanent Redirect类似于响应码301,但不允许HTTP方法改变
4XX 客户端错误
400 Bad Request客户端向服务器发出的请求使用了不正确的语法。这在正常的Web浏览时很不常见,但是在调试定制客户端时比较常见
401 Unauthorized访问这个页面需要身份认证,一般是用户名和口令。用户名和口令中可能有一个没有给出,或者用户名和口令无效
402 Payment Required现在没有使用,但将来可能用于指示访问该资源需要某种付费
403 Forbidden服务器理解请求,但有意地拒绝进行处理。身份认证没有任何帮助。当客户超出其配额时有时会使用这个响应码
404 NotFound最常见的错误响应,指示服务器找不到所请求的资源。它可能指示一个不正确的链接,已经移走而没有转发地址的文档,拼写错误的URL或其他类似情况
405 Method Not Allowed请求方法不支持指定的资源。例如:试图在不支持Put的web服务器上使用PUT放置文件,或者使用POS提交到只支持GET的URL
406 Not Acceptable所请求的资源不能以客户端希望的格式提供,客户端期望的格式由请求HTTP首部的Accept字段指示
407 Proxy Authentication Required中间代理服务器要求客户端在获取所请求的资源之前,先对客户端进行身份认证(可能需要用户名和口令)
408 Request Timeout客户端用了太长时间发送请求,可能是因为网络拥塞的原因
409 Conflict一个临时冲突阻止了请求的实现。例如,两个客户端试图同时PUT相同的文件
410 Gone与404类似,但更有把握地确定资源的存在性。资源已经有意地被删除(不是移走),不能恢复。应当删除响应的链接
411 Length Required客户端必须在请求HTTP的首部中发送一个Content-length字段,但没做到
412 Precondition Failed客户端在请求HTTP首部中指定的一个请求条件没有满足
413 Request Entity Too Large客户端请求主体大于服务器一次能够处理的大小
414 Request-URI Too long请求的URI太长。这对于防止某种缓冲区溢出攻击很重要
415 Unsupported Media Type服务器不理解或不接受请求主体的MIME content-type
416 Requested range Not Satisfiable服务器无法发送客户端所请求的字节范围
417 Expectation Failed服务器无法满足客户端在Expectrequest首部字段中给定的期望
418 I'm a teapot尝试用蜜罐泡咖啡
420 Enhance Your Calm服务器分级限制请求。这是非标准的,仅用于Twitter
422 Unprocessable Entity不能识别请求主体的内容类型,请求主体的语法是正确的,只是服务器无法处理
424 Faild Dependency由于之前一个请求的失败。导致这个请求失败
426 Upgrade Required客户端使用一个太老或不安全的HTTP协议版本
428 Precondition Required请求必须提供一个IF-Match首部
429 Too Many Request客户端被分级限制,要慢下来
431 Request Header Fields可能首部作为一个整体太大,或者某个首部字段太大
451 Unavailable For Legal Reasons这是一个试验性的响应码,由于法律原因禁止服务器提供请求服务
5XX 服务器错误
500 Internal Server Error发生了意外情况,服务器不知道如何处理
501 Not Implemented服务器不具有完成这个请求所需的一个特性。不能处理PUT请求的服务器可能会向试图PUT表单数据的客户端发送这个响应
502 Bad Gateway这个响应码只用于作为代理或者网关的服务器。它指示该代理在试图完成请求时,从它连接的服务器接收到一个无效的响应
503 Service Unavailable服务器暂时无法处理请求,可能是超负荷或维护原因。
504 Gateway Timeout代理服务器在合理的时间内未能接收到上游服务器的响应。所以无法将向客户端发送所需的响应
505 HTTP Version Not Supported服务器不支持客户端正在使用的HTTP版本
507 Insufficlient Storage服务器没有足够的空间来存放所提供的请求实体,通常用POST或者PUT
511 Network Authentication Required客户端需要身份认证才能访问网络
100-199 表示一个提供信息的响应码
200-299表示成功响应码
300-399 表示重定向
400-499表示客户端错误
500-599表示服务器错误
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: AD域全面管理维护手册v1.0是一份非常重要的文件,它可以帮助管理员更好地管理和维护活动目录(AD)域。 这份手册的内容非常丰富,包括了AD域的基本结构、对象、权限及策略,还有备份和恢复、监控和性能优化等方面的注意事项和步骤。这些功能模块的详细说明和操作指南为管理员提供了非常全面的操作手册,使他们在完善AD域的管理和维护方面更加得心应手。 此外,AD域全面管理维护手册v1.0提供了一系列一般和特殊情况的应急管理指南,如丢失域管理员账户、故障诊断等,以帮助管理员更好地应对各种紧急情况,从而保证AD域的安全性和可靠性。 最后,本手册还包含了常见错误和解决方法的详细说明,从而帮助管理员快速定位和解决AD域管理和维护过程中的一些常见问题。 总之,AD域全面管理维护手册v1.0是一份非常重要和实用的文件,它为管理员提供了一个全面的指南和操作手册,使他们可以更好地管理和维护AD域,从而确保公司的网络环境安全和可靠。 ### 回答2: AD域全面管理维护手册v1.0是一份专门针对企业内部Active Directory域的管理与维护所制定的手册。这份手册是由经验丰富的IT人员根据实际工作中遇到的问题和解决方案总结而成,旨在提供给广大企业技术支持人员作为参考。 在这份手册中,首先介绍了AD域的基本概念以及它所涉及到的诸多组件和服务,包括域控制器、LDAP、DNS、Kerberos等等。然后,手册详细讲解了如何进行AD域的设计与构建,包括域名的规划、组织单位的划分、用户和计算机的组织、GPO的配置等等。 接着,手册集中讨论了AD域的管理与维护。它概述了如何进行域用户和计算机的管理,包括账户管理、密码策略、访问控制等等。同时,它也讲解了如何进行域控制器的管理和维护,包括域控制器的备份和恢复、域控制器的升级和升级后的一些注意事项。 此外,手册也介绍了如何进行域服务的监视和故障排除。它包括了如何检查域服务的状态、如何识别和解决常见的域服务故障、如何收集并分析故障信息等等方面的内容。 总之,这份AD域全面管理维护手册v1.0是一份非常有价值的资源,它可以为企业技术支持人员提供指导和帮助,使他们更好地理解和管理AD域。 ### 回答3: AD域全面管理维护手册v1.0是企业中深入理解和掌握活动目录(AD)域的关键管理和维护知识的重要指南。该手册涵盖了多个方面,包括AD域的设计、实施、配置、用户管理、安全性和故障排除等工作流程。 在该手册中,首先介绍了AD域的重要性和作用,以及其对于企业内部环境的安全管理意义。其次,阐明了AD域的基础概念、结构和组织等基础知识。随后,说明AD域的标准架构和设计,包括域的名称、林的层次结构、域控制器和站点等元素。接下来,详细介绍了AD域的配置和管理,例如如何配置用户、计算机和组等对象,并进行访问控制和权限管理。 在维护方面,该手册重点讲解了安全证书、密码策略、群组策略、日志记录、备份和恢复、迁移和升级等AD域管理的关键领域。此外,还介绍了故障排除的流程和方法,例如如何检测和解决日志中的错误,如何诊断并解决AD域中的故障。 总的来说,该手册是企业中管理和维护活动目录域的重要参考指南。它为管理员提供了全面的AD域知识和技能,能够帮助管理员有效地维护和管理企业中的AD域系统,并为企业实现安全、高效和可靠的计算环境提供保障。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值