都是通信协议,也就是通信时所遵守的规则,仅仅有两方依照这个规则“说话”。对方才干理解或为之服务。
TCP
TCP/IP是个协议组。可分为四个层次:网络接口层、网络层、传输层和应用层。
在网络层有IP协议、ICMP协议、ARP协议、RARP协议和BOOTP协议。
在传输层中有TCP协议与UDP协议。
在应用层有FTP、HTTP、TELNET、SMTP、DNS等协议。
因此,HTTP本身就是一个协议,是从Webserver传输超文本到本地浏览器的传送协议。
socket:
这是为了实现以上的通信过程而建立成来的通信管道。其真实的代表是client和server端的一个通信进程,两方进程通过socket进行通信,而通信的规则採用指定的协议。
socket仅仅是一种连接模式,不是协议,tcp、udp,简单的说(尽管不准确)是两个最主要的协议,非常多其它协议都是基于这两个协议如,http就是基于tcp的,.用socket能够创建tcp连接,也能够创建udp连接。这意味着,用socket能够创建不论什么协议的连接。由于其它协议都是基于此的。
以下我们主要来看一下和我们互联网生活密切相关的协议:HTTP
什么是Http协议
HTTP全称是HyperText Transfer
Protocal。即:超文本传输协议。从1990年開始就在WWW上广泛应用,是现今在WWW上应用最多的协议,
Http是一个基于请求/响应模式的、无状态的协议。即我们通常所说的Request/Response。
URL:
URL(Uniform Resource Locator) 地址用于描写叙述一个网络上的资源,
schema://host[:port#]/path/…/[?query-string][#anchor]
scheme
host
port#
path
query-string
anchor-
URL 的一个样例
http://www.mywebsite.com/sj/test/test.aspx?name=sviergn&x=true#stuff
Schema:
host:
path:
Query
String:
Anchor:
HTTP的Request/Response:
先看Request 消息的结构,
第一部分叫Request line,
第三部分是body. header和body之间有个空行,
第一行中的Method表示请求方法,比方”POST”,”GET”,
当使用的是”GET” 方法的时候, body是为空的
比方我们打开博客园首页的request 例如以下
GET http://www.cnblogs.com/ HTTP/1.1
Host:
抽象的东西。难以理解,老感觉是虚的, 所谓眼见为实, 实际见到的东西,我们才干理解和记忆。 我们今天用Fiddler,实际的看看Request和Response.
以下我们打开Fiddler 捕捉一个博客园登录的Request 然后分析下它的结构, 在Inspectors tab下以Raw的方式能够看到完整的Request的消息,
Accept
作用:
比如:
假设server无法返回text/html类型的数据,server应该返回一个406错误(non acceptable)
通配符 * 代表随意类型
比如
Referer:
作用: 提供了Request的上下文信息的server,告诉server我是从哪个链接过来的,比方从我主页上链接到一个朋友那里,他的server就能够从HTTP Referer中统计出每天有多少用户点击我主页上的链接訪问他的站点。
比如: Referer:http://translate.google.cn/?hl=zh-cn&tab=wT
Accept-Language
作用: 浏览器申明自己接收的语言。
语言跟字符集的差别:中文是语言,中文有多种字符集,比方big5。gb2312,gbk等等。
比如: Accept-Language: en-us
Content-Type
作用:
比如:Content-Type: application/x-www-form-urlencoded
Accept-Encoding:
作用: 浏览器申明自己接收的编码方法,通常指定压缩方法,是否支持压缩,支持什么压缩方法(gzip。deflate)。(注意:这不是仅仅字符编码);
比如: Accept-Encoding: gzip, deflate
User-Agent
作用:告诉HTTPserver, client使用的操作系统和浏览器的名称和版本号.
我们上网登陆论坛的时候,往往会看到一些欢迎信息。当中列出了你的操作系统的名称和版本号,你所使用的浏览器的名称和版本号,这往往让非常多人感到非常奇妙,实际上。server应用程序就是从User-Agent这个请求报头域中获取到这些信息User-Agent请求报头域同意client将它的操作系统、浏览器和其它属性告诉server。
比如:
Connection
比如: Connection: keep-alive
比如:
Content-Length
作用:发送给HTTPserver数据的长度。
比如: Content-Length: 38
Host(发送请求时。该报头域是必需的)
作用: 请求报头域主要用于指定被请求资源的Internet主机和port号,它通常从HTTP URL中提取出来的
比如: 我们在浏览器中输入:http://www.guet.edu.cn/index.html
浏览器发送的请求消息中,就会包括Host请求报头域,例如以下:
Host:http://www.guet.edu.cn
此处使用缺省port号80。若指定了port号,则变成:Host:指定port号
Pragma
作用: 防止页面被缓存。 在HTTP/1.1版本号中。它和Cache-Control:no-cache作用一模一样
Pargma仅仅有一个使用方法, 比如: Pragma: no-cache
Cookie:
作用: 最重要的header, 将cookie的值发送给HTTP server
Accept-Charset
作用:浏览器申明自己接收的字符集。这就是本文前面介绍的各种字符集和字符编码,如gb2312。utf-8(通常我们说Charset包括了相应的字符编码方案)。
我们再看Response消息的结构, 和Request消息的结构基本一样。 相同也分为三部分
第一部分叫Response line,
第三部分是body. header和body之间也有个空行,
HTTP/version-number表示HTTP协议的版本号号,
我们用Fiddler 捕捉一个博客园首页的Response然后分析下它的结构, 在Inspectors
tab下以Raw的方式能够看到完整的Response的消息,
Cache-Control
作用: 这个是非常重要的规则。
这个用来指定Response-Request遵循的缓存机制。各个指令含义例如以下
Cache-Control:Public
Cache-Control:Private
Cache-Control:no-cache
还有其它的一些使用方法。 我没搞懂当中的意思, 请大家參考其它的资料
Content-Type
作用:WEBserver告诉浏览器自己响应的对象的类型和字符集,
比如:
Content-Type: text/html; charset=utf-8
Content-Type:text/html;charset=GB2312
Content-Type: image/jpeg
Expires
作用: 浏览器会在指定过期时间内使用本地缓存
比如: Expires: Tue, 08 Feb 2022 11:35:14 GMT
Last-Modified:
作用: 用于指示资源的最后改动日期和时间。(实例请看上节的If-Modified-Since的实例)
比如: Last-Modified: Wed, 21 Dec 2011 09:09:10 GMT
Server:
作用:指明HTTPserver的软件信息
比如:Server: Microsoft-IIS/7.5
X-AspNet-Version:
作用:假设站点是用ASP.NET开发的,这个header用来表示ASP.NET的版本号
比如: X-AspNet-Version: 4.0.30319
X-Powered-By:
作用:表示站点是用什么技术开发的
比如: X-Powered-By: ASP.NET
Connection
比如: Connection: keep-alive
比如:
Content-Length
指明实体正文的长度,以字节方式存储的十进制数字来表示。
在数据下行的过程中。Content-Length的方式要预先在server中缓存全部数据。然后全部数据再一股脑儿地发给client。
比如: Content-Length: 19847
作用:
比如: Date: Sat, 11 Feb 2012 11:35:14 GMT
HTTP协议之Get和Post
Http协议定义了非常多与server交互的方法,最主要的有4种,各自是GET,POST,PUT,DELETE. 一个URL地址用于描写叙述一个网络上的资源,而HTTP中的GET, POST, PUT, DELETE就相应着对这个资源的查,改。增。删4个操作。 我们最常见的就是GET和POST了。GET一般用于获取/查询资源信息,而POST一般用于更新资源信息.
我们看看GET和POST的差别
1. GET提交的数据会放在URL之后,以?
切割URL和数据传输,參数之间以&相连。如EditPosts.aspx?
name=test1&id=123456.
2. GET提交的数据大小有限制(由于浏览器对URL的长度有限制)。而POST方法提交的数据没有限制.
3. GET方式须要使用Request.QueryString来取得变量的值,而POST方式通过Request.Form来获取变量的值,也就是说Get是通过地址栏来传值,而Post是通过提交表单来传值。
4. GET方式提交数据,会带来安全问题,比方一个登录页面,通过GET方式提交数据时。username和password将出如今URL上,假设页面能够被缓存或者其它人能够訪问这台机器,就能够从历史记录获得该用户的账号和password.