JavaWeb系列八: WEB 开发通信协议(HTTP协议)

HTTP协议

  • 官方文档
  • 什么是HTTP协议
  • 快速入门
  • 页面请求的一个问题(分析)
  • http请求包分析(get)
  • http请求包分析(post)
  • GET请求 POST请求分别有哪些
  • http响应包分析
  • 常用的状态码说明
    • 状态码200
    • 状态码404
    • 状态码500
    • 状态码302
    • 状态码304
  • MIME类型
    • MIME介绍
    • 常见的 MIME 类型

在这里插入图片描述

官方文档

HTTP常见请求和响应头-说明.pdf

HTTP响应状态码说明.docx

什么是HTTP协议

1.超文本传输协议(HTTP, HyperText Transfer Protocol)是互联网上应用广泛的一种网络协议, 是工作在 tcp/ip协议基础上的, 所有的 www 文件都遵守这个标准.

2.http1.0 短连接; http1.1 长连接在这里插入图片描述

3.http 是 TCP/IP 协议的一个应用层协议, http 也是我们 web 开发的基础.

快速入门

1.看一个D:\idea_project\zzw_javaweb\zzw_servlet\web\http\hi.html
<h1>hello, http</h1>

2.使用火狐浏览器抓取 Http 请求和相应数据包
快捷键: ctrl+shift+i在这里插入图片描述

4.画出 http 请求 hi.html 的 UML时序图在这里插入图片描述

页面请求的一个问题(分析)

1.创建D:\idea_project\zzw_javaweb\zzw_servlet\web\http\test.html

<body>
<h1>abc</h1>
<img src="1.jpg"/>
<img src="2.jpg"/>

2.当访问 test.html 页面时, 问浏览器发出几次 http 请求?

1 次, 2 次, 3 次
答: 一共 3 次

3.解读
1)第一次请求test.html
2)当浏览器解析发现 test.html 中有 <img src="1.jpg"/> <img src="2.jpg"/>
3)会向服务器继续发送请求, 索要 1.jpg 和 2.jpg, 一共 3 次.

4.抓包说明在这里插入图片描述

http请求包分析(get)

1.HTTP 请求包分析(GET)图, 说明 可以通过浏览器抓包分析

  • 请求行
  • 请求头

2.说明: HTTP请求(GET)-有数据提交情况 WEB程序员要学会分析 Http 包!

●案例说明
在这里插入图片描述
在这里插入图片描述在这里插入图片描述

1)创建D:\idea_project\zzw_javaweb\zzw_servlet\web\http\login.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>登录</title>
</head>
<body>
<form action="../login" method="get">
    用户名: <input type="text" name="username" placeholder="用户名"><br>
    密 码: <input type="password" name="password" placeholder="密码"><br>
    <input type="submit" value="登录"/><input type="reset" value="重置"/>
</form>
</body>
</html>

2)创建D:\idea_project\zzw_javaweb\zzw_servlet\src\com\zzw\http\LoginServlet.java并配置

public class LoginServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        System.out.println("LoginServlet doGet method");
        //输出一句话,给浏览器
        //1.通过response获取流Print Writer,它可以给浏览器回复数据
        //2.为了让浏览器显示中文,需要告诉浏览器我们的编码是utf-8
        //解读: setContentType给回送数据设置编码
        //(1)text/html这个是MIME类型即告诉浏览器返回的数据是text类型下的html格式数据[MIME类型 大类型/小类型]
        //(2)charset=utf-8数据编码
        //细节: 设置编码格式要在.getWriter()之前
        response.setContentType("text/html; charset=utf-8");
        PrintWriter writer = response.getWriter();
        writer.print("<h1>登陆成功</h1>");

        //flush()会将缓存的数据刷新, 大多数语言的 close() 包含 flush()
        writer.flush();
        //close() 关闭流, 及时释放资源
        writer.close();
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

    }
}

web.xml

<servlet>
    <servlet-name>LoginServlet</servlet-name>
    <servlet-class>com.zzw.http.LoginServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>LoginServlet</servlet-name>
    <url-pattern>/login</url-pattern>
</servlet-mapping>

3)完成测试, 并抓包分析在这里插入图片描述

http请求包分析(post)

●基本介绍
1.post请求带url参数接收时跟get一样,用 @RequestParam接收,body里面内容用 @RequestBody接收

2.GET 有限制,POST两个地方都可以

●案例说明

1.修改 login.html, 将提交方式改成 post

<form action="../login" method="post">
    用户名: <input type="text" name="username" placeholder="用户名"><br>
    密 码: <input type="password" name="password" placeholder="密码"><br>
    <input type="submit" value="登录"/><input type="reset" value="重置"/>
</form>

2.修改D:\idea_project\zzw_javaweb\zzw_servlet\src\com\zzw\http\LoginServlet.java

public class LoginServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //输出一句话,给浏览器
        //1.通过response获取流Print Writer,它可以给浏览器回复数据
        //2.为了让浏览器显示中文,需要告诉浏览器我们的编码是utf-8
        //解读: setContentType给回送数据设置编码
        //(1)text/html这个是MIME类型即告诉浏览器返回的数据是text类型下的html格式数据[MIME类型 大类型/小类型]
        //(2)charset=utf-8数据编码
        //细节: 设置编码格式要在.getWriter()之前
        response.setContentType("text/html; charset=utf-8");
        PrintWriter writer = response.getWriter();
        writer.print("<h1>登陆成功</h1>");

        //flush()会将缓存的数据刷新, 大多数语言的 close() 包含 flush()
        writer.flush();
        //close() 关闭流, 及时释放资源
        writer.close();
    }
}

3.完成测试, 并抓包分析(post)
在这里插入图片描述

●说明: %E9%9F%A9%E9%A1%BA%E5%B9%B3url 编码 , 在服务端会自动解码 . UrlEncode编码/解码

GET请求 POST请求分别有哪些

●GET请求有哪些

  1. form 标签 method=get
  2. a 标签
  3. link 标签引入 css[以get方式来获取资源]
  4. Script 标签引入 js[以get方式来获取资源]
  5. img标签引入css[以get方式来获取资源]
  6. 在浏览器地址栏中输入地址敲回车

●POST请求有哪些

  1. form 标签 method=post
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>login</title>
    <link type="text/css" rel="stylesheet" href="css/my.css">
    <script type="text/javascript" src="js/my.js"></script>
</head>
<body>
<!--给LoginServlet发出Get请求-->
<form action="http://localhost:8080/http/login" method="post">
  username: <input type="text" name="username"/><br/>
  password: <input type="password" name="password"/><br/>
  <input type="submit" value="登录"/>
</form>
<a href="http://www.baidu.com">goto百度</a>
<img src="imgs/1.png" width="245px">
</body>
</html>

●GET传输的数据大小区别

  1. get传送的数据量较小, 不能大于2KB(不同浏览器不一样)
  2. post传送的数据量较大, 数据藏在请求体里, 一般默认不受限制

●什么情况下使用POST请求

  1. post请求是会在浏览器上隐藏参数部分的, 在安全要求的部分都会使用到POST请求, 比如用户登录, 数据增删改等等.都会把参数隐藏起来, 这样就不会通过请求暴露自己的参数格式
    比如: del?id=1, 别人就可以用del?id=2来删除你的其它数据
  2. 在向server传递的数据较大的时候, 使用POST, get是有限制的, 比如发帖, 上传文件

●什么情况下使用GET请求

  1. 在前台页面展示, 比如分页内容, 可以保留传递参数, 可用来非常好地分享和传播, POST中链接地址是不变化的
  2. get方式的安全性较post方式要差些, 包括机密信息的话, 建议使用post数据提交方式
  3. 在做数据查询时, 建议使用get方式; 而在做数据插入, 改动, 或删除时, 建议使用post方式

http响应包分析

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>login</title>
    <link type="text/css" rel="stylesheet" href="css/my.css">
    <script type="text/javascript" src="js/my.js"></script>
</head>
<body>
<!--给LoginServlet发出Get请求-->
<form action="http://localhost:8888/http/login" method="post">
  username: <input type="text" name="username"/><br/>
  password: <input type="password" name="password"/><br/>
  <input type="submit" value="登录"/>
</form>
<a href="http://www.baidu.com">goto百度</a>
<img src="imgs/1.png" width="245px">
</body>
</html>

在这里插入图片描述

常用的状态码说明

HTTP响应状态码说明

HTTP 常见请求和响应头-说明

状态码200

在这里插入图片描述

当浏览者访问一个网页时,浏览者的浏览器会向网页所在服务器发出请求。当浏览器接收并显示网页前,此网页所在的服务器会返回一个包含HTTP状态码的信息头(server header)用以响应浏览器的请求。
HTTP状态码的英文为HTTP Status Code。

  • 200
    OK 请求成功。一般用于GET与POST请求
    在这里插入图片描述
    在这里插入图片描述

状态码404

Not Found 服务器无法根据客户端的请求找到资源(网页)。通过此代码,网站设计人员可设置"您所请求的资源无法找到"的个性页面
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

状态码500

服务器内部错误, 无法完成请求.
在这里插入图片描述
在这里插入图片描述

状态码302

  • 301
    Moved Permanently 永久移动。请求的资源已被永久的移动到新URI,返回信息会包括新的URI,浏览器会自动定向到新URI。今后任何新的请求都应使用新的URI代替
  • 302
    Found 临时移动。与301类似。但资源只是临时被移动。客户端应继续使用原有URI

步骤

  1. 浏览器请求Status_302
  2. Status_302返回302的状态码, 并且指定浏览器重定向到login.html
  3. 浏览器发出第二次请求 访问login.html
  4. 浏览器测试抓包
    在这里插入图片描述
    在这里插入图片描述
public class Status_302 extends HttpServlet {
    //将两个请求合并
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //如果有一个请求来了
        // 重定向到servlet/login.html
        // (1)返回302状态码 (2)响应头会带上Location:/login.html
        response.sendRedirect("/servlet/login.html");
        //response.sendRedirect("http://www.baidu.com");
    }
}

状态码304

  • 304
    Not Modified 未修改。所请求的资源未修改,服务器返回此状态码时,不会返回任何资源。客户端通常会缓存访问过的资源,通过提供一个头信息指出客户端希望只返回在指定日期之后修改的资源

在这里插入图片描述

MIME类型

MIME介绍

MIME是HTTP协议中的数据类型. MIME的英文全称是"Multipurpose Internet Mail Extension", 即多功能Internet邮件扩展服务, MIME类型的格式是"大类型/小类型", 并与某一种文件的扩展名相对应

常见的 MIME 类型

文件MIME类型
超文本标记语言文本.html, .htm text/html
普通文本.txt text/plain
RTF文本.rtf application/rtf
GIF图形.gif image/gif
JPEG图形.jpeg, .jpg image/jpeg
au声音文件.au audio/basic
MIDI音乐文件.mid, midi audio/mid, audio/x-midi
RealAudio音乐文件.ra, .ram audio/x-pn-realaudio
MPEG文件.mpg, .mpeg video/mpeg
AVI文件.avi video/x-msvideo
GZIP文件.gz appcalition/x-gzip
TAR文件.tar application/x-tar

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/746364.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

一家大型银行的电子课程示例

Logrus IT的专家为最大的金融公司之一开发了一门课程&#xff0c;作为一个交互式路线图&#xff0c;向用户介绍公司的业务部门。我们的设计师以企业风格创造了独特的布局&#xff0c;每个课程模块都被创造性地表示为一个单独的建筑。用户可以在部门之间进行非线性导航&#xff…

Java基础:常用类(四)

Java基础&#xff1a;常用类&#xff08;四&#xff09; 文章目录 Java基础&#xff1a;常用类&#xff08;四&#xff09;1. String字符串类1.1 简介1.2 创建方式1.3 构造方法1.4 连接操作符1.5 常用方法 2. StringBuffer和StringBuilder类2.1 StringBuffer类2.1.1 简介2.1.2 …

编程设计思想

健康检查脚本 nmap:扫描端口 while true do healthycurl B:httpPORT/healthy -i | grep HTTP/1.1 | tail -n 1 | awk {print $2} done 批量操作类型脚本&#xff08;记录每一步日志&#xff09; 将100个nginx&#xff1a;vn推送到harbor仓库192.168.0.100 根据镜像对比sha值…

jdk1.8升级到jdk11遇到的各种问题

一、第三方依赖使用了BASE64Decoder 如果项目中使用了这个类 sun.misc.BASE64Decoder&#xff0c;就会导致错误&#xff0c;因为再jdk11中&#xff0c;该类已经被删除。 Caused by: java.lang.NoClassDefFoundError: sun/misc/BASE64Encoder 当然这个类也有替换方式&#xf…

mysql查询2个日期之间的数据,表字段只有年和月,无日期字段查询的解决

1.核心mysql查询 SELECT * FROM 表名 WHERE CONCAT(year, -, LPAD(month, 2, 0)) > 2022-02-08 AND CONCAT(year, -, LPAD(month, 2, 0)) < 2024-06-06;2.表结构 CREATE TABLE ys_datezzq (id int(10) NOT NULL AUTO_INCREMENT,bid int(10) NOT NULL DEFAULT 0 COMMEN…

海外云服务器与传统服务器的对比与选择

在信息技术快速发展的今天&#xff0c;海外云服务器和传统服务器成为企业和个人用户的两大选择。它们各有优势&#xff0c;适用于不同的使用场景和需求。下面&#xff0c;我们将从多个角度对这两种服务器进行深入对比&#xff0c;帮助您做出更明智的决策。 基础设施 海外云服务…

【神经网络】深入理解多层神经网络(深度神经网络

&#x1f388;个人主页&#xff1a;豌豆射手^ &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共同学习、交流进步&#xff01; 深入理解多层神经网络&#x…

【若依前后端分离】前端vue页面查看服务器本地的PDF

后端实现&#xff1a; 使用FileSystemResource包装文件&#xff0c;以便Spring MVC可以处理该资源 创建HttpHeaders对象以设置响应头 设置Content-Disposition头&#xff0c;使得浏览器以内联方式显示PDF&#xff08;即在浏览器中直接打开&#xff09; 设置Content-Type为appli…

编译器优化禁用对计算浮点加法运算时间的影响

编译器优化是现代编译器的重要功能&#xff0c;旨在提升程序的执行效率和性能。然而&#xff0c;在某些特定的测试或精确计算场景中&#xff0c;我们需要禁用这些优化以确保所有计算按预期执行。下面研究在 Keil 编译器中禁用和启用优化对执行多次次浮点除法运算时间的影响。 …

从云原生视角看 AI 原生应用架构的实践

本文核心观点&#xff1a; 基于大模型的 AI 原生应用将越来越多&#xff0c;容器和微服务为代表的云原生技术将加速渗透传统业务。API 是 AI 原生应用的一等公民&#xff0c;并引入了更多流量&#xff0c;催生企业新的生命力和想象空间。AI 原生应用对网关的需求超越了传统的路…

【SpringMVC】_SpringMVC实现留言墙

目录 1. 需求分析 2. 接口定义 2.1 提交留言 2.2 获取全部留言 3. 响应数据 4. 服务器代码 4.1 MessageInfo 文件 4.2 MessageController 文件 5. 前端页面代码 5. 运行测试 1. 需求分析 实现如下页面&#xff1a; 1、输入留言信息&#xff0c;点击提交后&#xff0…

Java版小程序商城免费搭建-直播商城平台规划及常见营销模式解析

平台概述 1. 平台组成 管理平台&#xff1a;提供全方位的系统设置、数据统计、商家管理、订单管理等后台管理功能。商家端&#xff1a;支持PC端和移动端操作&#xff0c;便于商家进行商品管理、订单处理、营销活动设置等。买家平台&#xff1a;覆盖H5网页、微信公众号、小程序…

MySQL实训--原神数据库

原神数据库 er图DDL/DML语句查询语句存储过程/触发器 er图 DDL/DML语句 SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS 0;DROP TABLE IF EXISTS artifacts; CREATE TABLE artifacts (id int NOT NULL AUTO_INCREMENT,artifacts_name varchar(255) CHARACTER SET utf8 COLLATE …

精益管理真的需要请咨询公司吗?看完这篇再决定

在当今这个追求效率和效益的时代&#xff0c;精益管理已成为众多企业提升竞争力的重要法宝。然而&#xff0c;面对复杂的精益转型过程&#xff0c;不少企业主和管理者开始犯难&#xff1a;做精益管理&#xff0c;一定要请咨询公司来帮忙吗&#xff1f;今天&#xff0c;我们就来…

DWC USB2.0协议学习1--产品概述

目录 1. 系统概述 1.1 AHB总线接口 1.2 Data RAM接口 1.3 PHY 接口 1.4 外部DMA控制器接口 1.5 其他可选接口 1.6 发送和接收FIFO 2. 功能列表 2.1 一般功能 2.2 可配置功能 2.3 应用接口功能 2.4 MAC-PHY接口特征 2.5 系统Memory体系结构 2.6 Non-DWORD对齐支持…

实训作业-人事资源管理系统

er图 模型图 DDL与DML DROP TABLE IF EXISTS departments; CREATE TABLE departments (department_id int(11) NOT NULL AUTO_INCREMENT COMMENT 部门ID,department_name varchar(100) NOT NULL COMMENT 部门名称,PRIMARY KEY (department_id),UNIQUE KEY department_name (de…

《黑神话悟空》电脑配置要求

《黑神话&#xff1a;悟空》这款国内优秀的3A游戏大作&#xff0c;拥有顶级的特效与故事剧情&#xff0c;自公布以来便备受玩家期待&#xff0c;其精美的画面与流畅的战斗体验&#xff0c;对玩家的电脑配置提出一定要求。那么这款优秀的游戏需要什么样的电脑配置&#xff0c;才…

BenchmarkSQL 对 MySQL 测试时请注意隔离级别!

BenchmarkSQL 是一款经典的开源数据库测试工具&#xff0c;内含了TPC-C测试脚本&#xff0c;可支持 Oracle、MySQL、PostgreSQL、SQL Server以及一些国产数据库的基准测试。 作者&#xff1a;李彬&#xff0c;爱可生 DBA 团队成员&#xff0c;负责项目日常问题处理及公司平台问…

GitLab配置免密登录之后仍然需要Git登录的解决办法

GitLab配置免密登录之后仍然需要Git登录的解决办法 因为实习工作需要&#xff0c;要在本地拉取gitlab上的代码&#xff0c;设置了密钥之后连接的时候还需要登录的token&#xff0c;摸索之后有了下面的解决办法。 方法一&#xff1a; 根据报错的提示&#xff0c;去网站上设置个人…

pytorch基础知识Tensor算术运算

1、Tensor的基本概念 标量是零维的张量&#xff0c;向量是一维的张量&#xff0c;矩阵是二维的张量 2、Tensor的创建 import torch"""常见的几个tensor创建""" a torch.Tensor([[1,2],[3,4]]) #2行2列的 print(a, a.type()) print(torch.on…