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

news2024/11/21 2:32:55

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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

不会吧!KVM竟然不支持磁盘的精简置备!?

正文共&#xff1a;999 字 17 图&#xff0c;预估阅读时间&#xff1a;1 分钟 前面我们安装了KVM主机&#xff08;KVM部署初体验&#xff09;&#xff0c;接下来肯定是要简单操作一下&#xff0c;体验体验如何使用。 上次我们是在主机的桌面环境中打开的“虚拟系统管理器VMM”&…

192.回溯算法:电话号码的字母组合(力扣)

代码解决 class Solution { public:// 定义每个数字对应的字母映射const string letterMap[10] {"", // 0"", // 1"abc", // 2"def", // 3"ghi", // 4"jkl", // 5"mno", // 6"pqrs&…

可以给任意软件exe一键加验证加卡密的免费工具!

目录 引言TProtect网络验证工具简介主要特性一键快速接入多平台支持高度安全灵活的用户和卡密设置自动更新与提示代理端支持高级模式防止多开机制 使用方法步骤一&#xff1a;获取TProtect工具步骤二&#xff1a;打开服务器步骤三&#xff1a;添加要加密的软件步骤四&#xff1…

关于Pycharm右下角不显示解释器interpreter的问题解决

关于Pycharm右下角不显示解释器interpreter的问题 在安装新的Pycharm后&#xff0c;发现右下角的 interpreter 的选型消失了&#xff1a; 觉得还挺不习惯的&#xff0c;于是网上找解决办法&#xff0c;无果。 自己摸索了一番后&#xff0c;发现解决办法如下&#xff1a; 勾…

科普文:贝叶斯过滤器判定垃圾邮件

简介 贝叶斯分类的运作是借着使用标记(一般是字词&#xff0c;有时候是其他)与垃圾邮件、非垃圾邮件的关连&#xff0c;然后搭配贝叶斯推断来计算一封邮件为垃圾邮件的可能性。 贝叶斯垃圾邮件过滤是非常有威力的技术&#xff0c;可以修改自己以符合个别使用者的需要&#xff0…

STM32HAL库--PWR低功耗实验(速记版)

电源控制&#xff08;PWR&#xff09;简介 电源控制部分&#xff08;PWR&#xff09;概述了不同电源域的电源架构以及电源配置控制器。PWR 的内容比较多&#xff0c;我们把它们的主要特性概括为以下 3 点&#xff1a; 电源系统&#xff1a;USB 稳压器、内核域(VCORE)、…

https基础概念

目录 1.什么是https 1.1.https概念 1.2.一些术语 2.https如何加密 2.1.使用对称加密 2.2.使用非对称加密 1.什么是https 首先&#xff0c;https不是http的复数形式 1.1.https概念 &#xff08;1&#xff09;产生背景 为什么会出现https&#xff0c;是因为http协议在传…

昇思25天学习打卡营第一天|快速入门

背景 华为组织了昇思25天学习营&#xff0c;从基础开始&#xff0c;提供算力支持&#xff0c;还是体验蛮好的。推荐大家报名参加。 学习内容 今天的内容是快速入门&#xff0c;很简单&#xff0c;当是复习基础内容了。 下载数据集》模型组网》模型训练》保存模型&#xff0c…

oracle 11g rac创建实例时发现只给一节点创建了实例 二节点没创建的处理方法

由于操作失误没有在二节点创建实例 删除数据库重新dbca建库 [oracleracdg1-1 dbs]$ dbca -silent -deleteDatabase -sourceDB rac11dg1 -sysDBAUserName sys -sysDBAPassword oracle_4U Connecting to database 4% complete 9% complete 14% complete 19% complete 23% …

electron+vue3+vite

1.创建工程 开源的electron构建脚手架&#xff1a;GitHub - electron-vite/electron-vite-vue: &#x1f973; Really simple Electron Vite Vue boilerplate. 1.使用命令创建工程&#xff08;node版本在16上&#xff09; npm create electron-vite 2.项目目录结构 2.安装依…

如何成为专业的 .NET 开发人员

如今&#xff0c;网上有大量信息&#xff0c;找到正确的信息并非易事。当你开始编程之旅并希望获得全面的指南时&#xff0c;最好寻找一个可以指导你完成整个过程的指南。 本文将帮助您制定一份路线图&#xff0c;告诉您什么是重要的以及什么是需要学习的. 一.一切从软件基础…

感谢我的辅导员—敬爱的罗老师

前言&#xff1a;快毕业了&#xff0c;想在毕业季感谢给予我帮助的老师&#xff0c;我的辅导员-罗老师是我最想感谢的大学老师。我不知道应该以什么样的方式去表达罗老师对我大学阶段的帮助&#xff0c;如果是直接发邮件&#xff0c;微信信息留言&#xff0c;可能在之后我和老师…

虚拟与现实的四种交互方式:复刻、增强、虚拟与混合。

经常有小伙伴搞不清楚这些概念&#xff0c;这次我就用极其浅显的语言和示例来说明这个问题。 "复刻现实"、"虚拟现实"、"增强现实"和"混合现实"是四种不同的技术概念&#xff0c;它们代表着不同的虚拟现实交互方式&#xff1a; 1. 复…

如何给小语种视频生成字幕

目前我们常看的有视频有中、英、日、韩这四种语言&#xff0c;如果我们想给其他的不常用的语言生成字幕怎么办&#xff1f;今天教大家如何给其他语言生成视频字幕文件 打开智游剪辑&#xff08;zyjj.cc&#xff09;搜索字幕生成&#xff0c;选择多语种那个就可以了 然后上传我们…

密码学及其应用 —— Java中的安全性

1. 简介 Java是一种广泛使用的编程语言&#xff0c;特别是在企业级解决方案中&#xff0c;比如使用J2EE、JavaBeans等技术。在Web开发领域&#xff0c;Java也有其应用&#xff0c;如客户端的applet和服务器端的Servlets/JSP。 1.1 Java的特点 面向对象&#xff1a;Java是一种面…

Keil 5编译出现misc.c(90): error: no member named ‘IP‘ in ‘NVIC_Type‘

no member named ‘IP’ in ‘NVIC_Type’ 我们在使用Keil 5编译器的AC6进行代码编译的使用&#xff0c;出现如下的错误&#xff1b; 当前的环境 编译器版本 Keil uVision5&#xff0c;V5.31.0.0&#xff1b; CMSIS-Core 版本V6…1.0&#xff1b; 采用GD32F407VK主芯片&…

[吃瓜教程]南瓜书第3章对数几率回归

第三章 对数几率回归 3.1 算法原理 对数几率回归&#xff08;Logistic Regression&#xff09;是一种统计方法&#xff0c;主要用于二分类问题。它通过拟合一个对数几率函数&#xff08;logit function&#xff09;&#xff0c;即对数几率&#xff08;log-odds&#xff09;与…

微信小程序传统开发登录和云开发登录的区别

1. 传统开发登录流程 1. 用户端调用wx.login从微信服务器获取code; 2. 用户端用wx.request将获取的code传递给后端服务器&#xff1b; 3. 后端服务器将拿到的code传给微信服务器&#xff0c;换取openid和session_key; 4. 后端服务器将获取到的信息返回给用户端&#xff1b…

添加阈值滞后以实现平滑的欠压/过压锁定

电阻分压器将高压衰减到低压电路可以承受的水平&#xff0c;而不会过驱动或损坏。在电源路径控制电路中&#xff0c;电阻分压器有助于设置电源欠压和过压锁定阈值。这种电源电压鉴定电路存在于汽车系统、电池供电的便携式仪器以及数据处理和通信板中。 欠压锁定 (UVLO) 可防止…

Talking Web

1. curl 1.1 http curl http://127.0.0.1:80 向目标主机端口发送http请求 1.2 httphead curl -H “Host: 18ed3df584cd48328b5839443aa7b42b” http://127.0.0.1:80 1.3 httppath curl http://127.0.0.1:80/853c64cd218f80d0a59665666fb2ab80 1.4 URL编码路径 &#xff0…