1.HTTP协议的主要特点
简单快速:统一资源服务
灵活:一个http类型能完成不同的数据传输
无连接:连接一次就会断掉,不会保持连接
无状态:客户端和服务端是两种身份,不能区分两次连接者的身份
2.HTTP报文的组成部分
HTTP报文包括两个部分:请求报文(1.请求行:包含http方法,页面地址,http协议以及版本 2.请求头:key,value值,告诉服务端要哪些内容 3.空行:告诉服务端空行之后就是请求体 4.请求体)和相应报文(状态行 响应头 空行 相应体)
3.HTTP方法
GET 获取资源
POST 传输资源
PUT 更新资源
DELETE 删除资源
HEAD 获得报文首部
4.POST和GET的区别
get在浏览器回退时时是无害的,而post会再次提交请求
get产生的url地址可以被收藏,而post不可以
get请求会被浏览器主动缓存,而post不会,除非手动设置
get请求只能进行url编码,而post支持多种编码方式
get请求参数会被完整保留在浏览器历史记录里,而post中的参数不会被保留
get请求在url中传送的参数是有长度限制的,而post没有限制
对于参数的数据类型,get只接受ASCLL字符,而post没有限制
get比post更不安全,因为参数直接暴露在url上,所以不能用来传递敏感信息
get参数通过传递,post放在Request body中
5.HTTP状态码
1xx: 指示信息-表示请求已接收,继续处理
2xx: 成功-表示请求已被成功接收
3xx: 重定向-要完成的请求必须进行更进一步的操作
4xx: 客户端错误-请求有语法错误或请求无法实现
5xx: 服务器错误-服务器未能实现合法的请求
200 OK 客户端请求成功
206 Partial Content: 客户发送了一个带有Range头的get请求,服务器完成了它
301 Moved Permanently: 所请求的页面已转移至新的url
302 Found:所请求的页面已临时转移至新的url
304 Not Modified: 客户端有缓冲的文档并发出一个条件性的请求,服务器告诉客户,原来缓冲的文档还可以继续使用
400 Bad Request: 客户端请求有语法错误,不能被服务器所理解
401 Unauthorized: 请求未授权,这个状态码必须和WWW-Authenticate报头域一起使用
403 Forbidden: 对被请求页面的访问被禁止
404 Not Found: 请求资源不存在
500 Internal Server Error: 服务器发生不可预期的错误原来缓冲的文档还可以继续使用
503 Server Unavailable: 请求未完成,服务器临时过载或当机,一段时间后可能恢复正常
6.什么是持久连接
在HTTP/1.0中,默认使用的是短连接。也就是说,浏览器和服务器每进行一次HTTP操作,就建立一次连接,但任务结束就中断连接。如果客户端浏览器访问的某个HTML或其他类型的 Web页中包含有其他的Web资源,如JavaScript文件、图像文件、CSS文件等;当浏览器每遇到这样一个Web资源,就会建立一个HTTP会话。但从 HTTP/1.1起,默认使用长连接,用以保持连接特性。使用长连接的HTTP协议,会在响应头有加入这行代码: Connection:keep-alive
7.什么是管线化
HTTP管线化是将多个HTTP要求(request)整批提交的技术,而在传送过程中不需先等待服务端的回应。管线化机制须通过永久连接(persistent connection)完成,仅HTTP/1.1支持此技术(HTTP/1.0不支持),并且只有GET和HEAD要求可以进行管线化,而POST则有所限制。此外,初次创建连接时也不应启动管线机制,因为对方(服务器)不一定支持HTTP/1.1版本的协议。