码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【图解HTTP】| 【01】简单了解HTTP协议


    文章目录

    • 索引
      • 1、HTTP协议用于客户端和服务端之间的通信
      • 2、通过请求和响应的交换达成通信
      • 3、HTTP是不保存状态的协议
      • 4、请求URI定位资源
      • 5、告知服务器意图的HTTP方法
      • 6、使用方法下达命令
      • 7、持久连接节省通信量
      • 8、使用Cookie的状态管理

    索引

    【图解HTTP】|【01】简单了解HTTP协议
    【图解HTTP】|【02】HTTP报文内的HTTP信息
    【图解HTTP】|【03】返回结果的HTTP状态码
    【图解HTTP】|【04】与HTTP协作的Web服务器(代理、网关、隧道)
    【图解HTTP】|【05】HTTP首部详解
    【图解HTTP】|【06】确保web安全的HTTPS
    【图解HTTP】|【07】确认访问用户身份的认证
    【图解HTTP】|【08】基于HTTP的功能追加协议
    【图解HTTP】|【09】Web的攻击技术

    1、HTTP协议用于客户端和服务端之间的通信

    在两台计算机之间使用HTTP协议通信时,在一条通信线路上必定有一端是客户端,另一端则是服务器端;
    
    • 1

    2、通过请求和响应的交换达成通信

    客户端先建立通信;
    下图中:
    	【Get】:为请求访问服务器的方法;
    
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述
    在这里插入图片描述

    3、HTTP是不保存状态的协议

    即无状态,该协议对于发送过的请求或响应不做持久化处理;
    - 不保留状态是为了更快地处理大量事务,确保协议的可伸缩性;
    
    但当登录账户时,由于其他操作要跳转到其他页面,此时需要保持登录状态,此时采用Cookie技术;
    
    • 1
    • 2
    • 3
    • 4

    4、请求URI定位资源

    访问服务器上的资源,若不是访问特定资源而是对服务器本身发起请求,可使用*来代替;
    
    • 1

    5、告知服务器意图的HTTP方法

    GET:获取资源

    请求访问已被URI识别的资源,资源经服务端解析返回响应内容;
    
    • 1

    POST:传输实体主体

    用来传输实体的主体;
    
    • 1

    PUT:传输文件

    自身不带验证机制,存在安全性问题;
    
    • 1

    HEAD:获得报文首部

    和GET一样,只是不返回报文主体部分,用于确认URI的有效性及资源更新的日期时间等;
    
    • 1

    DELETE:删除文件

    用来删除文件;
    
    • 1

    OPTIONS:询问支持的方法

    用来查询针对请求URI指定的资源支持的方法;
    
    • 1

    TRACE:追踪路径

    让Web服务器端将之前的请求通信环回给客户端的方法;
    	- 再Max-Forwards首部字段中填入数值,经过一个服务器端就将该数字减1,当减到0时,就停止继续传输;
    还能够查询发送出去的请求时如何被加工/篡改;
    	- 该方法不常用,容易引发XST攻击;
    
    • 1
    • 2
    • 3
    • 4

    CONNECT:要求用隧道协议连接代理

    该方法要求代理服务器通信时建立隧道,实现用隧道协议进行TCP通信,主要使用SSL和TLS加密后再隧道传输;
    
    • 1

    6、使用方法下达命令

    向请求URI指定的资源发送请求报文时,该命令被称为方法;
    方法即上述内容;
    
    • 1
    • 2

    在这里插入图片描述

    7、持久连接节省通信量

    在HTTP初始化版,每进行一次HTTP通信就要断开一次TCP连接;
    	- 那么,当一个页面需要多个图片、视频等,将会多次请求,增加通信量的开销;
    
    • 1
    • 2

    持久连接

    为了解决上述TCP连接问题,HTTP/1.1提供了keep-alive,只要没有任意一端提出断开连接,则保持TCP连接状态;
    	- 【好处】:减少了TCP连接的重复建立和断开造成的额外开销,减轻了服务端的负载,及开销时间,提高Web页面访问速度;
    自HTTP/1.1后所有连接都是默认是持久连接;
    
    • 1
    • 2
    • 3

    管线化

    使用该技术将不哦那个等待响应即可直接发送下一个请求,做到并行发送多个请求;
    	- 速度比持久连接还快;
    
    • 1
    • 2

    8、使用Cookie的状态管理

    HTTP是无状态协议,不保存状态即可减少服务器CPU及内存资源的消耗;
    	- 为了解决无法状态问题,于是引入Cookie技术,通过在请求和响应报文中写入Cookie信息来控制客户端信息;
    	- Cookie根据从服务端发送的响应报文内的Set-Cookie首部字段信息,回通知客户端保存Cookie,当下次客户端
    		发送请求时,客户端回自动在请求报文中加入Cookie值后发送出去;
    		服务器会坚持客户端发送的请求,对比服务器上的记录,得到之前的状态信息;
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

  • 相关阅读:
    大数据-玩转数据-Flink定时器
    C++模板进阶
    JavaWeb 学习笔记 7:Filter
    MySQL JDBC编程
    elment小结
    在国内购买GPT服务前的一定要注意!!!
    【进程间通信】进程间通信方式汇总
    十九、商城 - 运营商登录-Spring Security(7)
    好友让我看这段代码
    llvm源码windows编译
  • 原文地址:https://blog.csdn.net/weixin_45926547/article/details/125011213
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号