TCP协议
传输控制协议
点对点连接,可靠有序,全双工通信(双方可以互发数据),面向字节流
TCP协议建立连接的三次握手
- 客户端发送连接请求报文段
- 服务端收到连接请求,并返回确认
- 客户端再次发送确认报文段(指自己已经收到服务端的确认报文),这个时候发送的报文段已经可以携带数据
TCP协议断开连接的四次挥手
- 客户端发送断开请求
- 服务器收到断开请求,并返回确认
- 服务器发送断开连接的请求
- 客户端返回确认
socket
位于传输层之上,应用层之下,是对传输层的封装。
两个进程如何通信最主要的前提是能够唯一标示一个进程,在本地进程通讯中我们可以使用pid来唯一标示一个进程。
但是在网络中两个进程的pid有很大几率会冲突。所以通过ip地址+协议+端口号唯一标示网络中的一个进程。
IP层的ip地址可以唯一标示主机,而TCP层协议和端口号可以唯一标示主机的一个进程
socket是TCP/IP的抽象和封装,简化TCP/IP的操作难度,socket主要用来进行进程间的通信。
实际上网络间的通信还是基于TCP/IP的协议。
应用层
不同的应用对应具体的需求,同时也需要使用不同的应用层协议。之后会对http协议进行进一步解读。
socket解读
概念解释
Socket非常类似于电话插座。以一个国家级电话网为例,电话的通话双方相当于相互通信的2个进程,区号是它的网络地址;区内一个单位的交换机相当于一台主机,主机分配给每个用户的局内号码相当于Socket号。任何用户在通话之前,首先要占有一部电话机,相当于申请一个Socket;同时要知道对方的号码,相当于对方有一个固定的Socket。然后向对方拨号呼叫,相当于发出连接请求(假如对方不在同一区内,还要拨对方区号,相当于给出网络地址)。假如对方在场并空闲(相当于通信的另一主机开机且可以接受连接请求),拿起电话话筒,双方就可以正式通话,相当于连接成功。双方通话的过程,是一方向电话机发出信号和对方从电话机接收信号的过程,相当于向Socket发送数据和从socket接收数据。通话结束后,一方挂起电话机相当于关闭Socket,撤消连接。
socket又称套接字,底层建立连接通道,通过套接字建立连接。
socket是支持TCP/IP协议的网络通信的基本操作单元。它是网络通信过程中断点的抽象标示,包含进行网络通信的必须得五种信息
- 连接协议(tcp/ip)
- 源ip
- 源端口
- 目标ip
- 目标端口
socket的通信流程图
HTTP协议解读
http协议属于应用层协议,也是离数据最近的一层。
http发送是以报文的形式发送,报文的每一个地段都是ASCII码串。
Http请求报文,由4部分组成,请求行,请求头部,空行,请求体。
请求行
- 请求方法:GET,POST,HEAD(只返回响应头),PUT等
- URL:www.baidu.com
- 版本协议:HTTP/1.1
请求头
键值对的形式
- User-Agent:产生请求的浏览器类型。
- Accept:客户端可识别的内容类型列表。
- Host:请求的主机名,允许多个域名同处一个IP地址,即虚拟主机。
- Accept-Language:客户端可接受的自然语言。
- Accept-Encoding:客户端可接受的编码压缩格式。
- Accept-Charset:可接受的应答的字符集。
- connection:连接方式(close 或 keepalive)。
- Cookie:存储于客户端扩展字段,向同一域名的服务端发送属于该域的cookie。
空行
分割请求头和请求体的作用,表示接下来的内容为请求体。
请求体
主要是http请求的参数,GET请求中不需要这部分内容。
实例:username=11111&password=00000
这部分内容在GET请求中是加在URL后的。
响应报文
响应报文跟请求报文差不多,状态行,响应头,空行,响应体。
状态行
状态码:三位数字
- 1xx:表示服务器已接收了客户端请求,客户端可继续发送请求;
- 2xx:表示服务器已成功接收到请求并进行处理;
- 3xx:表示服务器要求客户端重定向;
- 4xx:表示客户端的请求有非法内容;
- 5xx:表示服务器未能正常处理客户端的请求而出现意外错误;
常见状态码:
- 200 OK:客户端请求成功。
- 400 Bad Request:客户端请求有语法错误,不能被服务器所理解。
- 401 Unauthorized:请求未经授权,这个状态代码必须和WWW-Authenticate报头域一起使用。
- 403 Forbidden:服务器收到请求,但是拒绝提供服务。
- 404 Not Found:请求资源不存在,举个例子:输入了错误的URL。
- 500 Internal Server Error:服务器发生不可预期的错误。
- 503 Server Unavailable:服务器当前不能处理客户端的请求,一段时间后可能恢复正常,举个例子:HTTP/1.1 200 OK(CRLF)。
响应头
- Location:Location响应报头域用于重定向接受者到一个新的位置。例如:客户端所请求的页面已不存在原先的位置,为了让客户端重定向到这个页面新的位置,服务器端可以发回Location响应报头后使用重定向语句,让客户端去访问新的域名所对应的服务器上的资源;
- Server:Server 响应报头域包含了服务器用来处理请求的软件信息及其版本。它和 User-Agent 请求报头域是相对应的,前者发送服务器端软件的信息,后者发送客户端软件(浏览器)和操作系统的信息。
- Vary:指示不可缓存的请求头列表;
- Connection:连接方式;对于请求来说:close(告诉 WEB 服务器或者代理服务器,在完成本次请求的响应后,断开连接,不等待本次连接的后续请求了)。keepalive(告诉WEB服务器或者代理服务器,在完成本次请求的响应后,保持连接,等待本次连接的后续请求);
- WWW-Authenticate:WWW-Authenticate响应报头域必须被包含在401 (未授权的)响应消息中,这个报头域和前面讲到的Authorization 请求报头域是相关的,当客户端收到 401 响应消息,就要决定是否请求服务器对其进行验证。如果要求服务器对其进行验证,就可以发送一个包含了Authorization 报头域的请求;
响应体
服务器返回的文本信息。
HTTP与HTTPS的区别
HTTPS是一种通过计算机网络进行安全通信的传输协议。HTTPS经由HTTP进行通信,但利用SSL/TLS来加密数据包。HTTPS开发的主要目的,是提供对网站服务器的身份 认证,保护交换数据的隐私与完整性。
HTTPS与HTTP相比,文字上只多了一个S,实际上在应用层之下多了一层安全层
从上图所示,HTTPS比HTPP就多了一个安全层,而这个安全层具体都做了些什么呢?
- 交换协议版本号
- 选择一个两端都了解的密码
- 对两端的身份进行认证
- 生成临时的会话密钥,以便加密信道。
WebSocket
最后
分享一份NDK基础开发资料
分享内容包括不限于高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter等全方面的Android进阶实践技术;希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!
utter等全方面的Android进阶实践技术;希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!