Java学习笔记之HTTP协议篇

HTTP简介

HTTP又称超文本传输协议(应用层),其支持C/S模式且简单、快速、灵活、无连接、无状态等特性

HTTP请求的报文结构
在这里插入图片描述
请求/响应

  1. 客户端连接到Web服务器;
  2. 发送HTTP请求;
  3. 服务器接受请求并返回HTTP响应;
  4. 释放TCP的连接;
  5. 客户端浏览器解析HTML内容。

问题:浏览器键入URL按下回车后经历的流程?

  1. DNS解析(DNS缓存:浏览器缓存、系统缓存、路由器缓存、IPS服务器缓存、根域名服务器缓存、顶级域名服务器缓存;逐层IP地址);
  2. TCP连接(三次握手);
  3. 发送HTTP请求;
  4. 服务器处理请求并返回HTTP报文;
  5. 浏览器解析渲染页面;
  6. 连接结束(四次挥手…)。

HTTP状态码
1XX:指示信息——表示请求已接收。继续处理
2XX:成功——表示请求已被成功接收
3XX:重定向——要完成请求必须进行更进一步的操作
4XX:客户端错误——请求语法错误或无法实现
5XX:服务器端错误——服务器未能实现合法的请求

GET和POST的区别

虽然这是个老生常谈的问题,但我突然发现身边有些小伙伴还是答不上来,所以就把它贴出来了。

  1. 从HTTP报文层面:GET将请求信息放在URL,POST放在报文体中;
  2. 从数据库层面:GET符合幂等性和安全性,POST不符合;
  3. 其他:GET可被缓存、储存,POST不行。

Cookie和Session的相关概念和区别

Cookie的设置和发送流程
在这里插入图片描述
注意:Cookie是保存文本信息在客户端中

Session的实现方法
1、利用Cookie保存JSESSIONID;
2、利用URL保存JSESSIONID发送给服务端(每个URL访问都会带有)。

Cookie和Session的区别

  1. Cookie数据存放在客户的浏览器上,Session数据放在服务器上;
  2. Session相对于Cookie更安全;
  3. Session可以减轻服务器的负担。

HTTPS的数据传输流程及其与HTTP的区别

HTTPS数据传输流程

  1. 浏览器将支持的加密算法信息发送给服务器;
  2. 服务器选择一套浏览器支持的加密算法,以证书的形式回发浏览器;
  3. 浏览器验证证书合法性,并结合证书公钥加密信息发送给服务器;
  4. 服务器使用私钥解密信息,验证哈希,加密响应消息回发浏览器;
  5. 浏览器解密响应消息,并对消息进行验证,之后进行加密交互数据

HTTP和HTTPS的区别

  1. HTTPS多了SSL(security sockets layer安全套接层);
  2. HTTPS需要CA的证书,HTTP不需要;
  3. HTTPS密文传输,HTTP明文传输;
  4. 连接方式不同,HTTPS默认使用443端口,HTTP使用80端口;
  5. HTTPS=HTTP+加密+认证+完整性保护,比HTTP安全。

问题:HTTPS安全吗?

:未必,由于浏览器默认填充http://,请求需要进行跳转,有被劫持的风险,可通过HSTS(HTTP Strict Transport Security)来优化。

附加:socket的通信流程:
在这里插入图片描述

结语:如有错误和问题欢迎在评论区下留言。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值