资讯专栏INFORMATION COLUMN

Android 面试必备 - http 与 https 协议

Wuv1Up / 1368人阅读

摘要:灵活允许传输任意类型的数据对象。无连接每次响应一个请求,响应完成以后就断开连接。无状态服务器不保存浏览器的任何信息。每次提交的请求之间没有关联。非流水线发出一个报文,等到响应,再发下一个报文。同时,流还支持优先级和流量控制。

版权声明:本文为博主原创文章,遵循[ CC 4.0
by-sa ](http://creativecommons.org/li...,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/gdutxia...

前言

在讲解 http 与 https 之间的区别之前,我么先来看一下一个常见的面试问题。

一次完整的 http 协议请求过程是怎样的

该图片出自 博客

Http协议的主要特点

支持客户/服务器模式

简单快速:客户向服务端请求服务时,只需传送请求方式和路径。

灵活:允许传输任意类型的数据对象。由Content-Type加以标记。

无连接:每次响应一个请求,响应完成以后就断开连接。

无状态:服务器不保存浏览器的任何信息。每次提交的请求之间没有关联。

怎么理解HTTP协议是无状态的无连接的的协议?

非持续性和持续性

HTTP1.0默认非持续性;HTTP1.1默认持续性

持续性:浏览器和服务器建立TCP连接后,可以请求多个对象

非持续性:浏览器和服务器建立TCP连接后,只能请求一个对象

非流水线和流水线

类似于组成里面的流水操作

流水线:不必等到收到服务器的回应就发送下一个报文。

非流水线:发出一个报文,等到响应,再发下一个报文。类似TCP。

http 各个版本之间的区别

1.0 与 1.1

http1.0一次只能处理一个请求,不能同时收发数据

http1.1可以处理多个请求,能同时收发数据

http1.1增加可更多字段,如cache-control,keep-alive.

2.0

http 2.0采用二进制的格式传送数据,不再使用文本格式传送数据

http2.0对消息头采用hpack压缩算法,http1.x的版本消息头带有大量的冗余消息

http2.0 采用多路复用,即用一个tcp连接处理所有的请求,真正意义上做到了并发请求,流还支持优先级和流量控制(HTTP/1.x 虽然通过 pipeline也能并发请求,但是多个请求之间的响应会被阻塞的,所以 pipeline 至今也没有被普及应用,而 HTTP/2 做到了真正的并发请求。同时,流还支持优先级和流量控制。)

http2.0支持server push,服务端可以主动把css,jsp文件主动推送到客户端,不需要客户端解析HTML,再发送请求,当客户端需要的时候,它已经在客户端了。

POST和GET的区别
Post一般用于更新或者添加资源信息 Get一般用于查询操作,而且应该是安全和幂等的
Post更加安全 Get会把请求的信息放到URL的后面
Post传输量一般无大小限制 Get不能大于2KB
Post执行效率低 Get执行效率略高
为什么POST效率低,Get效率高

Get将参数拼成URL,放到header消息头里传递

Post直接以键值对的形式放到消息体中传递。

但两者的效率差距很小很小

*

Https

HTTPS相当于HTTP的安全版本了,是在http的基础之上加上ssl(Secure Socket Layer)

端口号是443

是由SSL+Http协议构建的可进行加密传输、身份认证的网络协议。

https在客户端(浏览器)与服务端(网站)传输加密的数据大概经历一下流程

客户端将自己的has算法和加密算法发给服务器

服务器接收到客户端发来的加密算法和has算法,取出自己的加密算法与has算法,并将自己的身份信息以证书的形式发送给客户端,该证书信息包括公钥,网站地址,预计颁发机构等

客户端收到服务器发来的证书(即公钥),开始验证证书的合法性,如果证书信任,则生成一串随机的字符串数字作为私钥,并将私钥(密文)用证书(服务器的公钥)进行加密,发送给服务器

服务器收到客户端发来的数据之后,通过服务器自己的私钥进行解密客户端发来的数据(客户端的私钥),(这样双方都拥有私钥)再进行hash检验,如果结果一致,则将客户端发来的字符串(第3个步骤发送过来的字符串)通过加密发送给客户端

客户端解密,如果一致的话,就使用之前客户端随机生成的字符串进行对称加密算法进行加密

*

推荐阅读

聊一聊 Android中巧妙的位操作

二分查找的相关算法题

快速排序的相关算法题(java)

Android 面试必备 -计算机网络基本知识(TCP,UDP,Http,https)

360面试总结(Android)

扫一扫,欢迎关注我的公众号 stormjun94。如果你有好的文章,也欢迎你的投稿。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/76197.html

相关文章

  • Android 面试必备 - 计算机网络基本知识(TCP,UDP,Httphttps)

    摘要:在网络层有协议协议协议协议和协议。而且,因为有确认机制三次握手机制,这些也导致容易被人利用,实现等攻击。没有的这些机制,较被攻击者利用的漏洞就要少一些。但也是无法避免攻击的,比如攻击缺点不可靠,不稳定。 简介 HTTP协议(超文本传输协议)和 UDP(用户数据包协议),TCP 协议(传输控制协议) TCP/IP是个协议组,可分为四个层次:网络接口层、网络层、传输层和应用层。在网络层有I...

    My_Oh_My 评论0 收藏0
  • Android&Java面试题大全—金九银十面试必备

    摘要:需要校验字节信息是否符合规范,避免恶意信息和不规范数据危害运行安全。具有相同哈希值的键值对会组成链表。通过在协议下添加了一层协议对数据进行加密从而保证了安全。常见的非对称加密包括等。 类加载过程 Java 中类加载分为 3 个步骤:加载、链接、初始化。 加载。 加载是将字节码数据从不同的数据源读取到JVM内存,并映射为 JVM 认可的数据结构,也就是 Class 对象的过程。数据源可...

    renweihub 评论0 收藏0
  • 精彩文章大合集- 收藏集 - 掘金

    摘要:发布应用市场的平台抢红包工具红包精灵开源啦掘金红包精灵,如果喜欢,点个开源不易。作者将原素材文章进行了新内容的添加和重新排列,但是因为文章高效的代码编写技巧总结前端掘金本文总结了代码编写技巧,来提升你的和代码。 收藏安卓开发中非常实用优秀的库! 有图有真相! - Android - 掘金本来是打算收藏工具类的,但转念一想,已经有这么多优秀的库了,就没必要再去重复造轮子了,便归纳工作中比...

    ermaoL 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<