HTTP数据包

2023-10-26

HTTP协议和WEB应用

Web应用通常是指基于http的应用程序

在这里插入图片描述

HTTP协议简介

• HTTP协议是HyperTextTransferProtocol(超文本传输协议)的缩写是用于

从万维网服务器传输超文本到本地浏览器的传 送协议。

• HTTP是一个基于TCP/IP通信协议来传递数据(HTML文件,图片文件,查询结

果等)。

• HTTP是一个属于应用层的协议,由于其简捷、快速的方式,适用于分布式

超媒体信息系统。

• 目前在WWW中使用的是HTTP/1.1。web2.0

• HTTP协议工作于客户端-服务端架构(Client/S)为上。浏览器作为HTTP客

户端通过URL向HTTP服务端即WEB服务器发 送所有请求。

• Web服务器根据接收到的请求后,向客户端发送响应信息。

HTTP协议请求流程

HTTP处于TCP/IP协议层中的应用层
在这里插入图片描述

HTTP数据包请求结构

• 一个http数据包请求由4个部分组成:请求行、请求头标、空行、请求数据。

• 1.请求行:请求行由三个标记组成:请求方法、请求URL和HTTP版本,它 们使用空格分隔。如:GET /www.xxxx.com/index.html HTTP/1.1

• 2.请求头行:由关键字/值对组成,每一行头,关键字和值用冒号(:)分隔。

• 3.空行:最后一个请求头标之后是一个空行,发送回车符和退行,表示服 务器以下不再有头标。

• 4.请求数据:使用post传送数据,最常用的就是Content-Type和Content- Length头标。

在这里插入图片描述

HTTP协议请求方法

• get:向特定资源发出请求(请求指定页面信息,并返回实体主体);

• post:向指定资源提交数据进行处理请求(提交表单、上传文件),又可能导致 新的资源的建立或原有资源的修改;

• head:与服务器索与get请求一致的相应,响应体不会返回,获取包含在小消息 头中的原信息(与get请求类 似,返回的响应中没有具体内容,用于获取报头);

• put:向指定资源位置上上传其最新内容(从客户端向服务器传送的数据取代指定文档的内容),与post的区 别是put为幂等,post为非幂等;

• trace:回显服务器收到的请求,用于测试和诊断。trace是http8种请求方式之中 最安全的

• delete:请求服务器删除request-URL所标示的资源*(请求服务器删除页面)

• option:返回服务器针对特定资源所支持的HTML请求方法 或web服务器发送*测 试服务器功能(允许客户 端查看服务器性能);

• connect : HTTP/1.1协议中能够将连接改为管道方式的代理服务器;

HTTP请求之get和post的区别

• 1.GET提交的数据会放在 URL之后,以?分割URL 和传输数据,参数 之间 以 &相连,如EditPosts.aspx?name=test1&id=123456。POST方法是把提交的 数据放在HTTP包的Body中;

• 2.GET提交的数据大小有限制(因为浏览器对URL的长度有限制),而POST 方法提交的数据没有限制;

• 3.GET方式需要使用Request.QueryString来取得变量的值,而POST方式通 过Request.Form来获取变量的值;

• 4.GET方式提交数据,会带来安全问题,比如一个登录页面,通过GET方式 提交数据时,用户名和密码将出现在URL上,如果页面可以被缓存或者其 他人可以访问这台机器,就可以从历史记录获得该用户的账号和密码。
在这里插入图片描述
在这里插入图片描述

HTTP请求头部解析

• Accept:用于指定客户端接受哪些类型的信息。eg:Accept:image/gif;

• Accept-Charset:用于指定客户端接受的字符集。eg:Accept-Charset:iso-8859-1,gb2312;

• Accept-Encoding:用于指定可接受的内容编码。eg:Accept-Encoding:gzip.deflate;

• Accept-Language:用于指定一种自然语言。eg:Accept-Language:zh-cn;

• Authorization:用于证明客户端有权查看某个资源。当浏览器访问一个页面时,如果收到服务器的响应代码

为401(未授权),可以发送一个包含Authorization请求报头域的请求,要求服务器对其进行验证;

• Host:用于指定被请求资源的Internet主机和端口号;

• User-Agent:允许客户端将它的操作系统、浏览器和其它属性告诉服务器。会造成个人信息泄露;

• Cookie:某些网站为了辨别用户身份、进行 session 跟踪而储存在用户本地终端上的数据(通常经过加密);

• Referer:告知下一次请求服务器的来源页面链接。

HTTP响应头

• 1.状态行:状态行由三个部分组成;状态行、响应头标、空行、响应数据

• HTTP版本:向客户端指明其可理解的最高版本。

• 响应代码:3位数字代码,指出请求的成功或失败,如果失败则指出原因。

• 响应描述:为响应代码的可读性解释。

• 例如:HTTP/1.1 200 OK

• 2.响应头标:像请求头标一样,它们指出服务的功能,标识出响应数据的 细节。

• 3.空行:最后一个请求头标之后是一个空行,发送回车符和退行,表示服 务器以下不再有头标。

• 4.响应数据:HTML文档和图像等,也就是HTML本身。

在这里插入图片描述

HTTP响应状态码介绍

•-1xx:指示信息—表示请求已接收,继续处理。

•-2xx:成功—表示请求已经被成功接收、理解、接受。

•-3xx:重定向—要完成请求必须进行更进一步的操作。

•-4xx:客户端错误—请求有语法错误或请求无法实现。

•-5xx:服务器端错误—服务器未能实现合法的请求。

•200 OK:客户端请求成功

•301 redirect:页面永久性移走,服务器进行重定向跳转;

•302 redirect:页面暂时性移走,服务器进行重定向跳转,具有被劫持的安全风险;

•400 BadRequest:由于客户端请求有语法错误,不能被服务器所理解;

•401 Unauthonzed:请求未经授权。这个状态代码必须和WWW-Authenticate报头域一起使用;

•403 Forbidden:服务器收到请求,但是拒绝提供服务。服务器通常会在响应正文中给出不提供 服务的原因, 一般来说是服务器策略基于安全考虑拒绝提供访问;

•404 NotFound:请求的资源不存在,例如,输入了错误的URL;

•500 InternalServerError:服务器发生不可预期的错误,导致无法完成客户端的请求;

•503 ServiceUnavailable:服务器当前不能够处理客户端的请求,在一段时间之后,服务器可能 会恢复正常;

HTTP响应头部分析

相应的响应头用来描述服务器回给你对所返回的content的一些一些描述,我是什么服务器,返回的是啥编码, 返回的内容有多长等等。

Allow–对于特定资源的有效动作,例:Allow:GET,HEAD

Content-Encoding–响应资源所使用的编码类型。例: Content-Encoding:gzip

Content-Language–响应就内容所使用的语言,例: Content-Language:zh-cn

Content-Length–响应消息体的长度,用8进制字节表示Content-Length:348

Content-Location–所返回的数据的一个候选位置,例: Content-Location:/index.htm

Content-Type–当前内容的MIME类型,例: Content-Type:text/html;charset=utf-8

Date–此条消息被发送时的日期和时间(以RFC7231中定义的“HTTP日期”格式来表示),例:

Date:Tue,15Nov199408:12:31GMT

Expires–指定一个日期/时间,超过该时间则认为此回应已经过期,例: Expires:Thu,01Dec199416:00:00GMT

Location–用于在进行重定向,或在创建了某个新资源时使用,例: Location:http://www.itbilu.com/nodejs

Refresh–用于重定向,或者当一个新的资源被创建时。默认会在5秒后刷新重定向,例:

Refresh:5;url=http://itbilu.com

Server–服务器的名称,例: Server:nginx/1.6.3

Set-Cookie–设置HTTPcookie,例: Set-Cookie:UserID=itbilu;Max-Age=3600;Version=1

的资源被创建时。默认会在5秒后刷新重定向,例:

Refresh:5;url=http://itbilu.com

Server–服务器的名称,例: Server:nginx/1.6.3

Set-Cookie–设置HTTPcookie,例: Set-Cookie:UserID=itbilu;Max-Age=3600;Version=1

Status–通用网关接口的响应头字段,用来说明当前HTTP连接的响应状态。例: Status:200OK

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

HTTP数据包 的相关文章

随机推荐

  • shell编程基础

    1 它必须以如下行开始 必须放在文件的第一行 bin sh 符号 用来告诉系统执行该脚本的程序 本例使用 bin sh 编辑结束并保存后 如果要执行该脚本 必须先使其可执行 chmod x filename 此后在该脚本所在目录下 输入 f
  • 华为OD机试 - 字符串变换最小字符串(Java)

    题目描述 给定一个字符串s 最多只能进行一次变换 返回变换后能得到的最小字符串 按照字典序进行比较 变换规则 交换字符串中任意两个不同位置的字符 输入描述 一串小写字母组成的字符串s 输出描述 按照要求进行变换得到的最小字符串 备注 s是都
  • Oracle环境变量配置

    情况描述 最近在配置plsql环境后 plsql总是连接不上 由于对自己的记忆力过度自信 导致这个简单的问题不能得到解决 现在记录下来作为以后的参考 一 客户端安装 官网下载orcle对应版本的客户端 然后执行安装 二 环境变量 需要配置以
  • Futter 屏幕适配框架flutter_ScreenUtil 用法

    参考 前言 各位同学大家好 大家在做app开发的时候都会遇到屏幕适配的问题 安卓里面有dp iOS里面有pt 单位给我们用来处理屏幕适配 除此之外安卓还有 autosize等框架给我们使用 iOS也对应屏幕适配方案给我们使用 那么在flut
  • 基于Python的接口自动化unittest测试框架和ddt数据驱动详解

    这篇文章主要介绍了基于Python的接口自动化unittest测试框架和ddt数据驱动详解 本文给大家介绍的非常详细 对大家的学习或工作具有一定的参考借鉴价值 需要的朋友可以参考下 目录 引言 一 unittest测试框架 二 ddt数据驱
  • 用QML实现简单音视频播放器的实践

    用QML的MediaPlayer控件配合VideoOutput对可以对音频文件和视频文件进行播放 代码如下 VideoOutput id video out anchors fill parent source mediaPlayer Me
  • 给定一个无序整数数组,找出两个数字满足他们的和等于目标数字

    给定一个整数数组numbers 从数组中找出两个数满足相加之和等于目标数target 假设每个输入只对应唯一的答案 而且不可以使用重复的元素 返回两数下标值 以数组的形式返回 原始暴力算法 这个好想 建立两个嵌套的for循环 从头到尾遍历数
  • 【JDK新特性】一篇搞懂Lambda表达式 & 函数式接口

    必看 原创声明 转载请注明作者 文章来源 给伙伴们聊一下刷题事项 Lambda表达式 概述 Lambda是JDK8的语法糖 它可以对某些匿名内部类的写法进行简化 它是函数式编程的一个重要体现 让我们不用关注什么是对象 重点关注我们对数据做了
  • 夯实基础-JavaScript异步编程

    异步编程 JavaScript中异步编程问题可以说是基础中的重点 也是比较难理解的地方 首先要弄懂的是什么叫异步 我们的代码在执行的时候是从上到下按顺序执行 一段代码执行了之后才会执行下一段代码 这种方式叫同步 synchronous 执行
  • redis 配置

    root localhost hufh cd usr local src root localhost src ls redis 4 0 10 tar gz root localhost src tar zxvf redis 4 0 10
  • Vue 模拟通讯录列表用 js-pinyin 获取汉字首字母,形成字母索引

    效果图 流程 获取数据 提取首个字的拼音的首个字母 排序并分组 此功能用到Vant组件的 IndexBar 索引栏 1 安装 js pinyin npm地址 npm install js pinyin save 2 引入及使用
  • WindowsAPI 程序

    include
  • GZIP .gz 文件解压与压缩工具类

    package com ucf gatewaycheck utils import java util zip GZIPInputStream import java io FileOutputStream import java io F
  • 怎么提取图片里的颜色?图像颜色特征提取

    图像的颜色一直是研究和关注的热点 也是特征工程不可或缺的feature 今天就简单介绍一种非常基础的颜色的rgb特征 目的 我们希望图片的rgb特征转化成一个可衡量的指标 例如人的身高 体重 这样的指标173cm 60kg 用于后续工作 那
  • 在中断程序中,需要清中断标志,作用是什么?

    清中断标志的作用 响应中断条件是 中断使能和中断标志同时成立 一般来讲 响应中断后 有硬件清标志和软件清标志两种 如果硬件不能清标志 说明书会说明 单片机要靠查询中断标志来判断是否要进入中断 如果你不清除中断标志 本次中断退出 单片机又会检
  • ChatGPT 再遭禁用

    近日 三星电子宣布禁止员工使用流行的生成式AI工具 原因在于4月初三星内部发生的三起涉及 ChatGPT 误用造成的数据泄露事件 报道称 三星半导体设备测量资料 产品良率等内容或已被存入ChatGPT学习资料库中 去年11月上线以来 Cha
  • GoFrame系列:6、Swagger使用总结

    GoFrame系列 6 Swagger使用总结 文章目录 GoFrame系列 6 Swagger使用总结 1 swagger简述 2 GF框架使用swagger流程 3 示例 3 1 GET示例 3 2 POST示例 3 3 其它 4 最后
  • 各算法/协议知识理论笔记(fpga)

    一 利用fifo对3行数据求和 需要2个fifo保存第0行和第1行的数据 如下图 比如有20行数据 则将一行一行的输给fifo2 fifo2出来的数据再给fifo1 当fifo和fifo1有数据时 在准备给 fifo2输入新的一行数据时 同
  • python数据分析案例2

    load datasets import pandas as pd df 08 pd read csv all alpha 08 csv df 18 pd read csv all alpha 18 csv view 2008 datase
  • HTTP数据包

    HTTP协议和WEB应用 Web应用通常是指基于http的应用程序 HTTP协议简介 HTTP协议是HyperTextTransferProtocol 超文本传输协议 的缩写是用于 从万维网服务器传输超文本到本地浏览器的传 送协议 HTTP