iOS 网络相关

HTTP的请求方式都有哪些?

post、get、head、put、delete、options

安全:不应该引起Server端的任何状态变化。
get、head、options

幂等:同一个方法执行多次和执行一次的效果完全相同。

可缓存:请求是否可以被缓存。

HTTP 中的GET和POST方式有什么区别?

GET:是幂等的,可缓存的、安全的
POST:是不幂等的,不可缓存的、不安全的

状态码:
1** 信息,服务器收到请求,需要请求者继续执行操作
2** 成功,操作被成功接收并处理
3** 重定向,需要进一步的操作以完成请求
4** 客户端错误,请求包含语法错误或无法完成请求
5** 服务器错误,服务器在处理请求的过程中发生了错误

HTTP连接建立流程
TCP三次握手:
客户端向服务端发送SYN同步报文
服务端收到同步的报文之后或者说连接建立的报文之后返回客户端ACK同步报文
客户端收到之后 回应服务端一个ACK确认报文
TCP链接建立之后,进行HTTP的请求和相应

四次挥手:
客户端发送终止报文FIN到服务端
服务端收到终止报文后回给客户端一个ACK确认报文,此时客户端到服务端的链接就已经断开了,但是服务端到客户端方向可能还会传递数据
服务端向客户端发送一个FIN终止报文、ACK确认报文,然后由客户端回给服务端一个确认报文ACK,完成四次挥手

HTTP的特点:
无连接
HTTP的持久连接
无状态
Cookie / Session

Charles抓包原理是怎样的?
利用了HTTP的中间人攻击漏洞

HTTPS和HTTP有怎样的区别?

HTTPS = HTTP + SSL/ TLS (应用层之下,传输层之上的中间层)

HTTPS是安全的HTTP

HTTPS连接的建立流程?




TCP/UDP

都是传输层协议
TCP :传输控制协议
UDP :用户数据报协议

TCP为什么是三次握手?

解决同步报文超时重发的异常问题,不会建立多个连接

四次挥手




请简述TCP的慢开始过程




DNS解析存在哪些常见问题?

1、DNS劫持问题


截屏2021-03-11 下午4.39.19.png

2、DNS解析转发问题

DNS劫持与HTTP的关系是怎样的?


没有关系

DNS 解析发生在HTTP建立连接之前
DNS 解析请求使用UDP数据报,端口号53

怎么解决DNS劫持?

原有的DNS是使用DNS协议向DNS服务器的53端口进行请求
1、httpDNS:使用HTTP协议向DNS服务器的80端口进行请求
2、长连接
截屏2021-03-11 下午4.53.40.png
截屏2021-03-11 下午4.55.54.png
截屏2021-03-11 下午4.56.48.png
截屏2021-03-11 下午4.59.26.png

[图片上传中...(截屏2021-03-11 下午5.03.05.png-3cb6f9-1615453388970-0)]

截屏2021-03-11 下午5.01.51.png
截屏2021-03-11 下午5.03.48.png
截屏2021-03-11 下午5.05.24.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1、TCP/IP 及三次握手 2、socket编程 3、HTTP(图解HTTP) 从输入URL到页面加载发生了什么...
    ProgramDouglas阅读 3,971评论 0 0
  • 网络基础术语 HTTP:超文本传输协议,信息是明文传输的。 HTTPS:添加了加密及认证机制的HTTP,具有安全性...
    Dezi阅读 6,172评论 2 16
  • 1.网络模型 1.1 OSI 七层模型 某一层的服务就是该层及其下各层的一种能力,它通过接口提供给更高一层。 (关...
    wszyxc阅读 1,720评论 0 0
  • 网络相关 1.HTTP协议 超文本传输协议,它是客户端和服务器进行数据交互的一个重要的协议。 请求的组成部分 1....
    StevenHu_Sir阅读 1,747评论 0 4
  • 夜莺2517阅读 127,828评论 1 9

友情链接更多精彩内容