HTTP协议HTTP协议和TCP/IP协议族内的其他众多协议相同,用于客户端和服务器之间的通信。请求访问资源的一端为客户端,响应资源的一端为服务器。请求必须从客户端发出,而服务器回复响应,因此建立通信是从客户端开始的。请求报文POST /index.htm HTTP/1.1Host: hackr.jpConnection: keep-aliveContent-Type: application/x-www-form-urlencodedContent-Length: 16 name=ueno&age=25报文说明方法POSTURI/index.htm协议版本HTTP/1.1请求首部字段Host: hackr.jpConnection: keep-aliveContent-Type: application/x-www-form-urlencodedContent-Length: 16内容实体name=ueno&age=25响应报文HTTP/1.1 200 OKDate: Tue, 10 Jul 2012 06:50:15 GMTContent-Length: 363Content-Type: text/html <html>…报文说明协议版本HTTP/1.1 200 OK状态码200状态码的原因短语OK响应首部字段Date: Tue, 10 Jul 2012 06:50:15 GMTContent-Length: 363Content-Type: text/html主体<html>…HTTP是不保存状态的协议为了更快的处理大量的事物,确保协议的伸缩性,因此把HTTP协议设为无状态协议;为此,引入Cookie技术保存用户的登陆状态。HTTP请求方法GET:获取资源GET方法用来请求访问已被URI识别的资源。POST:传输实体主体虽然GET方法和POST方法都可以用来传输实体,但一般不用GET方法。GET与POST的区别方法GETPOST本质索取数据提交数据安全性低高执行效率高低机制将参数拼接在url上,明文传输将表单内各个字段与其内容放置在HTML HEADER内一起传送到action属性所指的URL地址大小取决于浏览器和系统理论上没有限制,取决于浏览器和系统地址栏输入支持不支持浏览器历史记录保留参数参数不保留编码方式url编码多种编码方式PUT:传输文件PUT方法用来传输文件,类似FTP协议文件上传,请求的报文中包含文件内容,然后保存在URI指定位置。但是HTTP/1.1的PUT方法不带验证机制,任何人都能上传文件,存在安全性问题,慎用。HEAD:获取报文首部类似GET方法,区别在于只返回报文首部,不返回报文主体。DELETE:删除文件与PUT方法相反,用来删除文件,DELETE方法按请求URI删除指定资源。但是HTTP/1.1的DELETE方法同样不带验证机制,存在安全性问题,慎用。区别OPTIONS:询问支持方法返回服务器支持的方法TRACE:追踪路径CONNECT:要求用隧道协议连接代理持久连接旨在建立1次TCP连接后进行多次请求和响应的交互,在HTTP/1.1中默认都是持久连接