Android网络框架

Android框架第(二)篇---网络基础

2017-11-12  本文已影响80人  ZebraWei

版权声明:本文为小斑马伟原创文章,转载请注明出处!


网络请求是APP开发中不可少的一项技能,随着业务逻辑的复杂性增加,市场各种各样的网络请求框架也因此孕育而生。然而在学习和工作中,刚开始的时候对Android网络编程框架使用,会感觉有很多疑难问题。出现这种状况,往往是对网络基础知识和理论认识不深不扎实。因此,需要一篇Web网络基础理论文章进行巩固下我们的IT大脑。
一、HTTP协议访问Web

我们都使用过浏览器来访问网页,当我们在地址栏中输入地址的时候,按下回车键的时候,我们想要访问的WEN数据就会显示在网页上。网页不会凭空出现,根据Web栏中指定的URL 访问服务器获取资源,再显示到我们的浏览器。像这种通过发送请求而获取服务器资源的Web浏览器 我们可以称作为客户端。而Web使用一种叫做HTTP协议 也就是超文本传输协议完成客户端到服务端等一系列的流程。可以说Web是建立在HTTP协议上通信的。

二、TCP/IP

通常使用的网络是在TCP/IP的基础上运行起来的,HTTP 者是TCP/IP内部的一个子集。像计算机都需要通过网络协议规则进行通信。TCP/IP是互联网相关的各类协议族的总称。

三、TCP/IP分层管理
四、TCP/IP通信传输流
TCP/IP通信传输流
五、HTTP相关的协议
六、TCP三次握手

当我们采用TCP协议 将数据包送出去之后 TCP协议不会对传输后的结果置之不理。一定会向对方确认是否一定送达。握手中采用了两个标记SYN 和ACK标记。发送端 ---SYN--> 接受端 ---SYN-ACK--> 发送端 --ACK-->接受端。 如果在过程中断,TCP按照相同数据将数据包再发送一次 直到握手成功。

七、URL和URI

URI(Uniform Resource Identifier) : 统一资源标识符 用于字符串标识某一互联网资源
URI(Uniform Resource Locator):统一资源定位符 表示资源的地点、为URI的子集

八、HTTP协议基础

HTTP协议通过请求和响应的交换达成通信


HTTP协议交互的信息(HTTP报文):用于HTTP协议交互的信息被称为HTTP报文 。

HTPP请求报文格式= 报文首部 + 空行 +报文主体
报文首部:请求行 + 请求首部字段 + 通用首部字段 + 实体首部字段 + 其他

九、HTTP请求和响应报文

HTTP请求报文:GET / HTTP/1.1 + 请求行信息 首部+ 换行 + 报文主体

HTTP请求报文事例
HTTP常用的请求方法:

HTTP响应报文
HTTP响应报文格式 = 报文首部 + 空行 +报文主体
报文首部:状态行 + 响应首部字段 +通用首部字段 + 实体首部字段 +其他


HTTP响应报文事例

HTTP响应状态码

HTTP响应码
十、HTTP首部

HTTP首部:首部字段是为了给浏览器和服务器提供报文主体、所使用的语音、认证信息等内容 HTTP首部字段是由首部字段名和字段值构成,中间用冒号“:”分割。
HTTP首部类型
通用首部字段:请求报文和响应报文均可以使用
请求首部字段:补充了请求的附加信息 客户端信息等
响应首部字段:补充了响应的附加内容
实体首部字段:补充了资源内容更新时间等于实体相关的信息
常用的HTTP首部类型
Cache-Control:控制缓存的行为
Host:请求资源所在服务器
Content-Endcoding:实体主体适用的编码方式
Content-Length: 实体主体的大小(单位:字节)
Content-Type:实体主体的媒体类型
Set-Cookie:开始状态管理所使用的Cookie信息,响应首部字段

十一、HTTPS原理和介绍

HTTP的缺点:通信使用明文,内容可能会被窃听,不验证通信的身份,因此可能遭遇伪装 无法证明报文的完整性所以有可能篡改。
HTTPS = HTTP + 加密 + 认证 + 完整性保护

十二、加密

HHTPS采用的混合加密机制:交换密钥环节使用公开密钥加密方式,交换报文阶段使用共享加密方式。

十二、认证机制

问题:公开加密方式无法证明公开密钥本身就是货真价实的公开密钥,公开密钥在传输途中可能就被篡改了。
解决方法:使用数字证书认证机构(CA)和其相关机构颁发的公开密钥证书,加入数字证书认证的加密过程

HTTPS的完整性保护:应用层使用HTTPS发送数据时,会附加一种叫做MAC的报文摘要,MAC能够查知报文是否遭到篡改,从而保证报文的完整性
HHTPS的问题 通信速度慢(还需要增加SSL通信) 处理速度慢 (还需要进行加密和认证)

上一篇 下一篇

猜你喜欢

热点阅读