Android 面试必备 - http 与 https 协议

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

本文连接:https://blog.csdn.net/gdutxia...java

前言

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

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

image

该图片出自 博客浏览器

Http协议的主要特色

  1. 支持客户/服务器模式
  2. 简单快速:客户向服务端请求服务时,只需传送请求方式和路径。
  3. 灵活:容许传输任意类型的数据对象。由Content-Type加以标记。
  4. 无链接:每次响应一个请求,响应完成之后就断开链接。
  5. 无状态:服务器不保存浏览器的任何信息。每次提交的请求之间没有关联。

怎么理解HTTP协议是无状态的无链接的的协议?安全

非持续性和持续性

HTTP1.0默认非持续性;HTTP1.1默认持续性服务器

持续性:浏览器和服务器创建TCP链接后,能够请求多个对象网络

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

非流水线和流水线

相似于组成里面的流水操做jsp

  • 流水线:没必要等到收到服务器的回应就发送下一个报文。
  • 非流水线:发出一个报文,等到响应,再发下一个报文。相似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在客户端(浏览器)与服务端(网站)传输加密的数据大概经历一下流程

    1. 客户端将本身的has算法和加密算法发给服务器
    2. 服务器接收到客户端发来的加密算法和has算法,取出本身的加密算法与has算法,并将本身的身份信息以证书的形式发送给客户端,该证书信息包括公钥,网站地址,预计颁发机构等
    3. 客户端收到服务器发来的证书(即公钥),开始验证证书的合法性,若是证书信任,则生成一串随机的字符串数字做为私钥,并将私钥(密文)用证书(服务器的公钥)进行加密,发送给服务器
    4. 服务器收到客户端发来的数据以后,经过服务器本身的私钥进行解密客户端发来的数据(客户端的私钥),(这样双方都拥有私钥)再进行hash检验,若是结果一致,则将客户端发来的字符串(第3个步骤发送过来的字符串)经过加密发送给客户端
    5. 客户端解密,若是一致的话,就使用以前客户端随机生成的字符串进行对称加密算法进行加密

    image

      • *

    推荐阅读

    聊一聊 Android中巧妙的位操做

    二分查找的相关算法题

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

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

    360面试总结(Android)

    Android技术人(stormjun94)

    扫一扫,欢迎关注个人公众号 stormjun94。若是你有好的文章,也欢迎你的投稿。

    相关文章
    相关标签/搜索