• 通信协议:HTTP、TCP、UDP


    好久没有更新我的博客了, 预计都长霉了.. 项目都忙得差点儿相同了,  公司这两天也搬家了 , 先来没事 就写点东西.咱今天不提代码如何,说点其它的 先来谈谈iOS开发中常见的通信协议  ,废话不说了,  直接来....

    都是通信协议,也就是通信时所遵守的规则,仅仅有两方依照这个规则“说话”。对方才干理解或为之服务。

    TCP   HTTP   UDP三者的关系:

    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是应用层协议。当你上网浏览网页的时候,浏览器和Webserver之间就会通过HTTP在Internet上进行数据的发送和接收。

    Http是一个基于请求/响应模式的、无状态的协议。即我们通常所说的Request/Response。

     

    URL

    URL(Uniform Resource Locator) 地址用于描写叙述一个网络上的资源,  基本格式例如以下

    schema://host[:port#]/path/…/[?query-string][#anchor]

    scheme               指定低层使用的协议(比如:http, https, ftp)

    host                   HTTPserver的IP地址或者域名

    port#                 HTTPserver的默认port是80,这样的情况下port号能够省略。假设使用了别的port,必须指明,比如 http://www.cnblogs.com:8080/

    path                   訪问资源的路径

    query-string       发送给httpserver的数据

    anchor-            

    URL 的一个样例

    http://www.mywebsite.com/sj/test/test.aspx?name=sviergn&x=true#stuff

    Schema:                 http
    host:                   www.mywebsite.com
    path:                   /sj/test/test.aspx
    Query String:           name=sviergn&x=true
    Anchor:                 stuff

     

    HTTPRequest/Response

    先看Request 消息的结构,   Request 消息分为3部分

    第一部分叫Request line,

     第二部分叫Request header,

    第三部分是body. header和body之间有个空行,

     结构例如以下图

    第一行中的Method表示请求方法,比方”POST”,”GET”,  Path-to-resoure表示请求的资源, Http/version-number 表示HTTP协议的版本号号

    当使用的是”GET” 方法的时候, body是为空的

    比方我们打开博客园首页的request 例如以下

    GET http://www.cnblogs.com/ HTTP/1.1
    Host: www.cnblogs.com

    抽象的东西。难以理解,老感觉是虚的, 所谓眼见为实, 实际见到的东西,我们才干理解和记忆。 我们今天用Fiddler,实际的看看Request和Response.

    以下我们打开Fiddler 捕捉一个博客园登录的Request 然后分析下它的结构, 在Inspectors tab下以Raw的方式能够看到完整的Request的消息,

     例如以下图

     

    Accept

    作用: 浏览器端能够接受的媒体类型,

    比如:  Accept: text/html  代表浏览器能够接受server回发的类型为 text/html  也就是我们常说的html文档,

    假设server无法返回text/html类型的数据,server应该返回一个406错误(non acceptable)

    通配符 * 代表随意类型

    比如  Accept: */*  代表浏览器能够处理全部类型,(一般浏览器发给server都是发这个)

    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。

    比如: User-Agent: Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0; CIBA; .NET CLR 2.0.50727; .NET CLR 3.0.4506.2152; .NET CLR 3.5.30729; .NET4.0C; InfoPath.2; .NET4.0E)

    Connection

    比如: Connection: keep-alive   当一个网页打开完毕后,client和server之间用于传输HTTP数据的TCP连接不会关闭,假设client再次訪问这个server上的网页。会继续使用这一条已经建立的连接

    比如:  Connection: close  代表一个Request完毕后,client和server之间用于传输HTTP数据的TCP连接会关闭, 当client再次发送Request,须要又一次建立TCP连接。

    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,

     第二部分叫Response header。

    第三部分是body. header和body之间也有个空行,

     结构例如以下图

    HTTP/version-number表示HTTP协议的版本号号,  status-code 和message 请看下节[状态代码]的详解.

    我们用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   当一个网页打开完毕后,client和server之间用于传输HTTP数据的TCP连接不会关闭,假设client再次訪问这个server上的网页,会继续使用这一条已经建立的连接

    比如:  Connection: close  代表一个Request完毕后,client和server之间用于传输HTTP数据的TCP连接会关闭, 当client再次发送Request,须要又一次建立TCP连接。

    Content-Length

    指明实体正文的长度,以字节方式存储的十进制数字来表示。

    在数据下行的过程中。Content-Length的方式要预先在server中缓存全部数据。然后全部数据再一股脑儿地发给client。

    比如: Content-Length: 19847

     Date

    作用:  生成消息的详细时间和日期

    比如: Date: Sat, 11 Feb 2012 11:35:14 GMT

    HTTP协议之GetPost

    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.  POST方法是把提交的数据放在HTTP包的Body中.

    2. GET提交的数据大小有限制(由于浏览器对URL的长度有限制)。而POST方法提交的数据没有限制.

    3. GET方式须要使用Request.QueryString来取得变量的值,而POST方式通过Request.Form来获取变量的值,也就是说Get是通过地址栏来传值,而Post是通过提交表单来传值。

    4. GET方式提交数据,会带来安全问题,比方一个登录页面,通过GET方式提交数据时。username和password将出如今URL上,假设页面能够被缓存或者其它人能够訪问这台机器,就能够从历史记录获得该用户的账号和password.

  • 相关阅读:
    C​S​S3​:​transition与visibility
    CSS ::before 和 ::after 伪元素 进阶
    [转]达梦数据库报错:不能同时包含聚集KEY和大字段(text类型)
    [转].netcore webapi post参数长度超过最大限制
    efcore执行sql查询(无需定义dbset<model>)
    Rabbitmq的死信
    用Docker搭建RabbitMq的普通集群和镜像集群
    .NetCore在IdentityServer4因为Cookies的SameSite导致授权登录跳转回登录页的问题
    2021>2022
    js 宽高相关及其应用
  • 原文地址:https://www.cnblogs.com/brucemengbm/p/7402834.html
Copyright © 2020-2023  润新知