http 协议
http协议:Hypertext Transfer Protocol,超文本传输协议。是浏览器和服务器间进行的通信的一种规范。
iso公司制定的osi7层协议,只是在理论层面,实际更加倾向于5层(会话、表示、应用合为一层)而所谓的Tcp\Udp协议就是跑在传输层与应用层之间的。
tcp可靠,但需要连接
udp不可靠
----------->可靠,不需要连接的协议http协议(bs架构需要可靠传输)
一个完整的http请求消息,包含一个请求行,若干个消息头,换行,实体内容。
1、请求行
- 描述客户端的请求方式、请求资源的名称、http协议的版本号。
2、消息头

1、Host 请求的web服务器域名地址 2、User-Agent HTTP客户端运行的浏览器类型的详细信息。 通过该头部信息,web服务器可以判断出http请求的客户端的浏览器的类型。 3、Accept 指定客户端能够接收的内容类型,内容类型的先后次序表示客户都接收的先后次序 4、Accept-Lanuage 指定HTTP客户端浏览器用来展示返回信息优先选择的语言 5、Accept-Encoding 指定客户端浏览器可以支持的web服务器返回内容压缩编码类型。表示允许服务器在将输出内容发送到客户端 以前进行压缩,以节约带宽。而这里设置的就是客户端浏览器所能够支持的返回压缩格式。 6、Accept-Charset HTTP客户端浏览器可以接受的字符编码集 7、Content-Type 显示此HTTP请求提交的内容类型。一般只有post提交时才需要设置该属性 有关Content-Type属性值有如下两种编码类型: (1)“application/x-www-form-urlencoded”: 表单数据向服务器提交时所采用的编码类型, 默认的缺省值就是“application/x-www-form-urlencoded”。 然而,在向服务器发送大量的文本、包含非ASCII字符的文本或二进制数据时这种编码方式效率很低。 (2)“multipart/form-data”: 在文件上载时,所使用的编码类型应当是“multipart/form-data”, 它既可以发送文本数据,也支持二进制数据上载。 当提交为表单数据时,可以使用“application/x-www-form-urlencoded”;当提交的是文件时, 就需要使用“multipart/form-data”编码类型。 8、Keep-Alive 表示是否需要持久连接。如果web服务器端看到这里的值为“Keep-Alive”,或者看到请求使用的是HTTP 1.1 (HTTP 1.1默认进行持久连接),它就可以利用持久连接的优点

POST / HTTP1.1 Host:www.wrox.com User-Agent:Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 2.0.50727; .NET CLR 3.0.04506.648; .NET CLR 3.5.21022) Content-Type:application/x-www-form-urlencoded Content-Length:40 Connection: Keep-Alive name=Professional%20Ajax&publisher=Wiley
3、换行
4、实体内容
就是指浏览器端通过http协议发送给服务器的实体数据。
get请求时,通过url传给服务器的值。
post请求时,通过表单发送给服务器的值。
一个完整的http响应消息,包含一个状态行,若干个消息头,实体内容。
1、消息头
2、状态行
3、实体内容
响应包含浏览器能够解析的静态内容,例如:html,纯文本,图片等等信息
1、简单快速
客户向服务器请求服务式,只需要传送方法和路径。
方法:POST 、GET、HEAD
--------》程序规模小,通信速度快
2、灵活
允许任何类型的数据对象传输,类型由Context-Type加以标记
3、无连接
限制每次连接只处理一个请求。处理完断开,可以节约时间。
4、无状态
无状态是指协议对于事务处理没有记忆能力。缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。另一方面,在服务器不需要先前信息时它的应答就较快。
状态代码有三位数字组成,第一个数字定义了响应的类别,共分五种类别:
1xx:指示信息--表示请求已接收,继续处理
2xx:成功--表示请求已被成功接收、理解、接受
3xx:重定向--要完成请求必须进行更进一步的操作
4xx:客户端错误--请求有语法错误或请求无法实现
5xx:服务器端错误--服务器未能实现合法的请求
常见状态码:
200 OK //客户端请求成功
400 Bad Request //客户端请求有语法错误,不能被服务器所理解
401 Unauthorized //请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用
403 Forbidden //服务器收到请求,但是拒绝提供服务
404 Not Found //请求资源不存在,eg:输入了错误的URL
500 Internal Server Error //服务器发生不可预期的错误
503 Server Unavailable //服务器当前不能处理客户端的请求,一段时间后可能恢复正常
1、GET提交,请求的数据会附在URL之后,以?分割URL和传输数据,多个参数用&连接;例 如:login.action?name=hyddd&password=idontknow&verify=%E4%BD%A0 %E5%A5%BD。如果数据是英文字母/数字,原样发送,如果是空格,转换为+,如果是中文/其他字符,则直接把字符串用BASE64加密,得出如:%E4%BD%A0%E5%A5%BD,其中%XX中的XX为该符号以16进制表示的ASCII。
POST提交,把提交的数据放在HTTP包的包体中。
2、传输数据的大小
HTTP协议没有对传输的数据大小进行限制,HTTP协议规范也没有对URL长度进行限制。
实际情况:
- GET方式:特定的浏览器和服务器对URL的长度有限制
- POST方式:理论上数据不受限,但实际各个WEB服务器会规定post提交数据大小进行限制。
GET方式需要使用Request.QueryString来取得变量的值,而POST方式通过Request.Form来获取变量的值。