当前位置: 首页 > news >正文

Servlet笔记(下)

HttpServletRequest对象相关API

+ 获取请求行信息相关(方式,请求的url,协议及版本)

| API                           | 功能解释                       |

| ----------------------------- | ------------------------------ |

| StringBuffer getRequestURL(); | 获取客户端请求的url            |

| String getRequestURI();       | 获取客户端请求项目中的具体资源 |

| int getServerPort();          | 获取客户端发送请求时的端口     |

| int getLocalPort();           | 获取本应用在所在容器的端口     |

| int getRemotePort();          | 获取客户端程序的端口           |

| String getScheme();           | 获取请求协议                   |

| String getProtocol();         | 获取请求协议及版本号           |

| String getMethod();           | 获取请求方式                   |

+ 获得请求头信息相关

| API                                   | 功能解释               |

| ------------------------------------- | ---------------------- |

| String getHeader(String headerName);  | 根据头名称获取请求头   |

| Enumeration<String> getHeaderNames(); | 获取所有的请求头名字   |

| String getContentType();              | 获取content-type请求头 |

+ 获得请求参数相关

| API                                                     | 功能解释                             |

| ------------------------------------------------------- | ------------------------------------ |

| String getParameter(String parameterName);              | 根据请求参数名获取请求单个参数值     |

| String[] getParameterValues(String parameterName);      | 根据请求参数名获取请求多个参数值数组 |

| Enumeration<String> getParameterNames();                | 获取所有请求参数名                   |

| Map<String, String[]> getParameterMap();                | 获取所有请求参数的键值对集合         |

| BufferedReader getReader() throws IOException;          | 获取读取请求体的字符输入流           |

| ServletInputStream getInputStream() throws IOException; | 获取读取请求体的字节输入流           |

| int getContentLength();                                 | 获得请求体长度的字节数               |

+ 其他API

| API                                          | 功能解释                    |

| -------------------------------------------- | --------------------------- |

| String getServletPath();                     | 获取请求的Servlet的映射路径 |

| ServletContext getServletContext();          | 获取ServletContext对象      |

| Cookie[] getCookies();                       | 获取请求中的所有cookie      |

| HttpSession getSession();                    | 获取Session对象             |

| void setCharacterEncoding(String encoding) ; | 设置请求体字符集            |

HttpServletResponse相关API

+ 设置响应行相关

| API                        | 功能解释                   |

| -------------------------- | -------------------------- |

| void setStatus(int  code); | 设置响应状态码             |

+ 设置响应头相关

| API                                                    | 功能解释                                         |

| ------------------------------------------------------ | ------------------------------------------------ |

| void setHeader(String headerName, String headerValue); | 设置/修改响应头键值对                            |

| void setContentType(String contentType);               | 设置content-type响应头及响应字符集(设置MIME类型) |

+ 设置响应体相关

| API                                                       | 功能解释                                                |

| --------------------------------------------------------- | ------------------------------------------------------- |

| PrintWriter getWriter() throws IOException;               | 获得向响应体放入信息的字符输出流                        |

| ServletOutputStream getOutputStream() throws IOException; | 获得向响应体放入信息的字节输出流                        |

| void setContentLength(int length);                        | 设置响应体的字节长度,其实就是在设置content-length响应头 |

+ 其他API

| API                                                          | 功能解释                                            |

| ------------------------------------------------------------ | --------------------------------------------------- |

| void sendError(int code, String message) throws IOException; | 向客户端响应错误信息的方法,需要指定响应码和响应信息 |

| void addCookie(Cookie cookie);                               | 向响应体中增加cookie                                |

| void setCharacterEncoding(String encoding);                  | 设置响应体字符集                              |

请求转发和响应重定向

 什么是请求转发和响应重定向

 请求转发和响应重定向是web应用中间接访问项目资源的两种手段,也是Servlet控制页面跳转的两种手段, 请求转发通过HttpServletRequest实现,响应重定向通过HttpServletResponse实现

请求转发

1 请求转发时,请求和响应对象会继续传递给下一个资源

2 请求中的参数可以继续向下传递

 请求转发特点(背诵)

+ 请求转发通过HttpServletRequest对象获取请求转发器实现

+ 请求转发是服务器内部的行为,对客户端是屏蔽的

+ 客户端只发送了一次请求,服务端只产生了一对requestresponse对象,客户端地址栏不变

+ 服务端只产生了一对请求和响应对象,这一对请求和响应对象会继续传递给下一个资源

+ 因为全程只有一个HttpServletRequset对象,所以请求参数可以传递,请求域中的数据也可以传递

+ 请求转发可以转发给其他Servlet动态资源,也可以转发给一些静态资源以实现页面跳转

+ 请求转发可以转发给WEB-INF下受保护的资源(此时可以访问到这些受保护的资源,直接访问则不行)

+ 请求转发不能转发到本项目以外的外部资源

代码举例

ServletA请求转发到ServletB

@WebServlet("/servletA")
public class ServletA extends HttpServlet {@Overrideprotected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {System.out.println("servletA执行了");String money = req.getParameter("money");System.out.println("servletA获得参数:money="+money);//请求转发给ServletBRequestDispatcher requestDispatcher = req.getRequestDispatcher("servletB");//让请求转发器做出转发动作requestDispatcher.forward(req,resp);//将请求转发给一个视图(a.html)// RequestDispatcher requestDispatcher1 = req.getRequestDispatcher("WEB-INF/b.html");//requestDispatcher1.forward(req,resp);}
}
@WebServlet("/servletB")
public class ServletB extends HttpServlet {@Overrideprotected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {System.out.println("servletB执行了");String money = req.getParameter("money");System.out.println("servletB获得参数:money="+money);}
}

 响应重定向

 响应重定向特点(背诵)

 响应重定向通过HttpServletResponse对象的sendRedirect方法实现

 响应重定向是服务端通过302响应码和路径,告诉客户端自己去找其他资源,是在服务端提示下的,客户端的行为 客户端至少发送了两次请求,客户端地址栏是要变化的

请求产生了多次后端就会有多个request对象

+ 服务端产生了多对请求和响应对象,且请求和响应对象不会传递给下一个资源

+ 因为全程产生了多个HttpServletRequset对象,所以请求参数不可以传递,请求域中的数据也不可以传递

+ 重定向可以是其他Servlet动态资源,也可以是一些静态资源以实现页面跳转

+ 重定向不可以到给WEB-INF下受保护的资源

+ 重定向可以到本项目以外的外部资源

过程图

 乱码问题

GET请求乱码

> GET请求方式乱码分析

+ GET方式提交参数的方式是将参数放到URL后面,如果使用的不是UTF-8,那么会对参数进行URL编码处理

+ HTML中的 <meta charset='字符集'/> 影响了GET方式提交参数的URL编码

+ tomcat10.1.7URI编码默认为 UTF-8

+ 当GET方式提交的参数URL编码和tomcat10.1.7默认的URI编码不一致时,就会出现乱码

解决方式:

 方式1  :设置GET方式提交的编码和Tomcat10.1.7的URI默认解析编码一致即可 (推荐)

方式2 : 设置Tomcat10.1.7的URI解析字符集和GET请求发送时所使用URL转码时的字符集一致即可,修改conf/server.xml中 Connecter 添加 URIEncoding="GBK"  (不推荐)------------------对于请求行的url这一部分,解码使用的字符集为GBK

 POST方式请求乱码

例如:当html文件使用GBK进行编码,而Tomcat默认用UTF-8进行解码,我们采用解决get乱码问题的第二种方式来解决post乱码问题,即,修改conf/server.xml中 Connecter 添加 URIEncoding="GBK" ,我们发现修改后还是有乱码问题,这是因为post请求的参数是放在请求体里的,而非url

> POST请求方式乱码分析

+ POST请求将参数放在请求体中进行发送

+ 请求体使用的字符集受到了<meta charset="字符集"/> 的影响

+ Tomcat10.1.7 默认使用UTF-8字符集对请求体进行解析

+ 如果请求体的URL转码和Tomcat的请求体解析编码不一致,就容易出现乱码

POST请求方式乱码解决

+ 方式1 : 请求时,使用UTF-8字符集提交请求体 (推荐)

+ 方式2 : 后端在获取参数前,设置解析请求体使用的字符集和请求发送时使用的字符集一致 (不推荐)             设置请求体的解码使用的字符集:req.setCharacterEncoding("字符集");

路径问题

相对路径

        以当前资源的所在路径为出发点去找目标资源

        语法:不以/开头

        ./表示当前资源的路径

        ../表示当前资源的上一层路径

        缺点:目标资源路径受到当前资源路径的影响 不同位置相对路径写法不同

    + 相对路径的规则是: 以当前资源所在的路径为出发点去寻找目标资源

                      规则就是在当前资源的所在路径后,拼接目标资源的路径,然后发送请求找目标资源

    + 相对路径不以 / 开头

    + 在file协议下,使用的是磁盘路径

    + 在http协议下,使用的是url路径

    + 相对路径中可以使用 ./表示当前资源所在路径,可以省略不写

    + 相对路径中可以使用../表示当前资源所在路径的上一层路径,需要时要手动添加

 绝对路径

        始终以固定的路径作为出发点去找目标资源

        语法:以/开头

        不同项目中,固定的路径出发点可能不一致

        缺点:绝对路径要补充项目的上下文 项目的上下文是可以改变的

        如何解决:

        通过head>base>href属性,定义相对路径公共前缀,通过公共前缀把一个相对路径转化为绝对路径(不完美)

    + 绝对路径的规则是: 使用以一个固定的路径做出出发点去寻找目标资源,和当前资源所在的路径没有关系

    + 绝对路径要以/ 开头

    + 绝对路径的写法中,不以当前资源的所在路径为出发点,所以不会出现  ./ ../

    + 不同的项目和不同的协议下,绝对路径的基础位置可能不同,要通过测试确定

    + 绝对路径的好处就是:无论当前资源位置在哪,寻找目标资源路径的写法都一致

+ 应用场景

    1. 前端代码中,href src action 等属性

    2. 请求转发和重定向中的路径

响应重定向,请求转发路径问题

             二者相对路径写法规则与上面一致

            请求转发的绝对路径是不需要添加项目上下文的

            请求转发的/ 代表的路径是 http://localhost:8080/项目上下文路径/

如何解决项目上下文更变的问题:将项目上下文设置为/

相关文章:

Servlet笔记(下)

HttpServletRequest对象相关API 获取请求行信息相关(方式,请求的url,协议及版本) | API | 功能解释 | | ----------------------------- | ------------------------------ | | StringBuffer getRequestURL(); | 获取客户端…...

Windows 中学习Docker环境准备3、在Ubuntu中安装Docker

Windows 中学习Docker环境准备1、Win11安装Docker Desktop Windows 中学习Docker环境准备2、Docker Desktop中安装ubuntu Windows 中学习Docker环境准备3、在Ubuntu中安装Docker 需要更多Docker学习视频和资料&#xff0c;请文末联系 步骤 1&#xff1a;更新系统并安装依赖…...

【centOS】搭建公司内网git环境-GitLab 社区版(GitLab CE)

1. 安装必要的依赖 以 CentOS 7 系统为例&#xff0c;安装必要的依赖包&#xff1a; sudo yum install -y curl policycoreutils openssh-server openssh-clients postfix sudo systemctl start postfix sudo systemctl enable postfix2. 添加 GitLab 仓库 curl -sS https:/…...

Unity DoTween使用文档

DoTween 使用文档 DoTween 是 Unity 中非常流行的动画补间插件。它通过链式调用方式&#xff0c;让开发者可以快速创建平滑、自然的动画效果。本文将介绍 DoTween 的基础用法、缓动曲线原理&#xff08;包含常见缓动曲线的数学公式与参数说明&#xff09;、案例演示以及一些常…...

【办公类-99-01】20250201学具PDF打印会缩小一圈——解决办法:换一个PDF阅读器

背景需求&#xff1a; 2024年1月13日&#xff0c;快要放寒假了&#xff0c;组长拿着我们班的打印好的一叠教案来调整。 “前面周计划下面的家园共育有调整&#xff0c;你自己看批注。” “还有你这个教案部分的模版有问题&#xff0c;太小&#xff08;窄&#xff09;了。考虑…...

组合总和II(力扣40)

这道题的难点就在于题目所给的集合中有重复的数字&#xff0c;我们需要进行去重操作。首先明确去重指的是去重哪一部分。注意并不是对递归的集合去重&#xff0c;而是对当前集合的遍历进行去重。这么说可能有点抽象&#xff0c;举个例子&#xff1a;假设集合为1,1,2,3,4&#x…...

基于HTML生成网页有什么优势

在互联网时代&#xff0c;网页是人们获取信息、交流互动的重要窗口&#xff0c;而基于HTML生成网页&#xff0c;是搭建网络大厦的关键。HTML语法简洁直观&#xff0c;标签和属性语义明确&#xff0c;新手也能迅速上手&#xff0c;创建包含基础元素的网页&#xff0c;极大降低了…...

php 接入扣子的 token获取

本身逻辑只是个api&#xff0c;但是官方不提供php的sdk 扎心了老铁&#xff0c;这下php 狗都不用了&#xff0c;主要麻烦的是如何获取access_token&#xff0c;代码如下 protected function get_jwt(): string{$header [alg > RS256,typ > JWT,kid > $this->kid];…...

Redis02 - 持久化

Redis持久化 文章目录 Redis持久化一&#xff1a;持久化简介1&#xff1a;Redis为什么要进行持久化2&#xff1a;Redis持久化的方式 二&#xff1a;RDB持久化介绍1&#xff1a;手动触发RDB2&#xff1a;自动触发RDB3&#xff1a;redis.conf中进行RDB的配置4&#xff1a;RDB优缺…...

【力扣】240.搜索二维矩阵 II

题目 我的代码 class Solution { public:bool searchMatrix(vector<vector<int>>& matrix, int target) {for(int i0;i<matrix.size();i){for(int j0;j<matrix[0].size();j){if(targetmatrix[i][j]){return true;}else if(target<matrix[i][j]){brea…...

RabbitMQ 从入门到精通:从工作模式到集群部署实战(二)

接上篇&#xff1a;《RabbitMQ 从入门到精通&#xff1a;从工作模式到集群部署实战&#xff08;一&#xff09;》 链接 文章目录 4.安装RabbitMQ Messaging Topology Operator 裸金属环境部署RabbitMQ部署单实例部署集群 4.安装RabbitMQ Messaging Topology Operator 使用 cer…...

编程AI深度实战:大模型哪个好? Mistral vs Qwen vs Deepseek vs Llama

随着开源 LLM 的发展&#xff0c;越来越多的模型变得专业化&#xff0c;“代码”LLM 变得非常流行。这些 LLM 旨在比其 “常识” 对应物更小&#xff0c;但旨在超越更大的通用模型的编码性能。 这些模型以极低的成本提供大型模型的功能&#xff0c;进一步使本地 LLM 空间民主化…...

11.kafka开启jmx

方式一: 1.进入/opt/kafka_2.13-3.3.2/bin目录 命令: cd /opt/kafka_2.13-3.3.2/bin [root@rhel77 ~]# cd /opt/kafka_2.13-3.3.2/bin [root@rhel77 bin]# pwd /opt/kafka_2.13-3.3.2/bin [root@rhel77 bin]# 2.备份kafka-run-class.sh 命令: cp kafka-run-class.sh …...

基于钉钉API的连接器实现:企业数据集成与自动化管理

文章目录 概要背景与需求钉钉API概述连接器实现小结 概要 在当今数字化时代&#xff0c;企业面临着海量数据的管理与整合挑战。钉钉作为国内广泛使用的办公协作平台&#xff0c;提供了丰富的API接口&#xff0c;支持企业进行数据集成与自动化管理。本文将介绍如何通过钉钉API实…...

JAVA 二维列表的基础操作与异常

在Java中创建二维 ArrayList&#xff08;即嵌套列表&#xff09;的方法有多种&#xff0c;下面我将详细介绍常用的几种方式&#xff0c;并分析它们的区别和适用场景。 1. 使用嵌套 ArrayList 创建二维列表 方法一&#xff1a;直接嵌套 ArrayList 这是最常用的方法&#xff0c…...

将仓库A分支同步到仓库B分支,并且同步commit提交

一、 问题 有一仓库A 和 一仓库B&#xff0c; 需要将仓库A分支a1所有提交同步推送到仓库B分支b1上 二、 解决 2.1、 首先需要仓库A、仓库B的权限&#xff0c; 2.2、将仓库A clone到本地&#xff0c; 进入A目录&#xff0c;并且切换到a1分支 cd A ## A 为A仓库clone到本地代…...

使用java代码操作rabbitMQ收发消息

SpringAMQP 将来我们开发业务功能的时候&#xff0c;肯定不会在控制台收发消息&#xff0c;而是应该基于编程的方式。由于RabbitMQ采用了AMQP协议&#xff0c;因此它具备跨语言的特性。任何语言只要遵循AMQP协议收发消息&#xff0c;都可以与RabbitMQ交互。并且RabbitMQ官方也…...

mysql8安装时提示-缺少Microsoft Visual C++ 2019 x64 redistributable

MySQL8.0安装包mysql-8.0.1-winx64进行安装&#xff0c;提示&#xff1a;This application requires Visual Studio 2019 x64Redistributable, Please install the Redistributable then runthis installer again。出现这个错误是因为我们电脑缺少Microsoft Visual C 这个程序&…...

WindowsServer搭建内网Gitea【中文更方便使用】

特点&#xff1a; 轻量级&#xff1a;占用系统资源少&#xff0c;对服务器硬件要求较低&#xff0c;适合小型企业或团队使用。部署和维护相对简单&#xff0c;即使没有专业的运维人员也能轻松搭建。 功能齐全&#xff1a;具备基本的代码托管功能&#xff0c;如仓库管理、分支管…...

leetcode 907. 子数组的最小值之和

题目如下 数据范围 观察数据范围理论上平方复杂度的算法计算次数逼近1e9还不至于超时&#xff0c;但是由于有mod 1e9导致超时。所以本题不能靠暴力枚举来解决。 所以我们可以思考如何在枚举上面减少计算次数&#xff1a;第一种枚举法&#xff1a;最外层i控制子数组的左边界&…...

WordPress自定义.js文件排序实现方法

在WordPress中&#xff0c;要将插件引用的.js文件放到所有.js文件之后加载&#xff0c;可以通过以下方法实现&#xff1a; 方法一&#xff1a;调整wp_enqueue_script的加载顺序 在插件的主文件中&#xff0c;使用wp_enqueue_script函数加载.js文件时&#xff0c;将$in_footer…...

摄像头模块烟火检测

工作原理 基于图像处理技术&#xff1a;分析视频图像中像素的颜色、纹理、形状等特征。火焰通常具有独特的颜色特征&#xff0c;如红色、橙色等&#xff0c;且边缘呈现不规则形状&#xff0c;还会有闪烁、跳动等动态特征&#xff1b;烟雾则表现为模糊、无固定形状&#xff0c;…...

【拼十字——树状数组】

题目 暴力代码 30% #include <bits/stdc.h> using namespace std; using ll long long; const int N 1e5 10; const int mod 1e9 7; int n; int l[N], w[N], c[N]; int main() {cin >> n;ll ans 0;for (int i 1; i < n; i){cin >> l[i] >> …...

脚手架开发【实战教程】prompts + fs-extra

创建项目 新建文件夹 mycli_demo 在文件夹 mycli_demo 内新建文件 package.json {"name": "mycli_demo","version": "1.0.0","bin": {"mycli": "index.js"},"author": "","l…...

Fiddler Classic(HTTP流量代理+半汉化)

目录 一、关于Fiddler (一) Fiddler Classic (二) Fiddler Everywhere (三) Fiddler Everywhere Reporter (四) FiddlerCore (五) 总结 二、 软件安全性 1. 软件安装包 2. 软件汉化dll 三、安装与半汉化 1. 正常打开安装包点击下一步安装即可&#xff0c;安装路径自…...

基于yolov11的阿尔兹海默症严重程度检测系统python源码+onnx模型+评估指标曲线+精美GUI界面

【算法介绍】 基于YOLOv11的阿尔兹海默症严重程度检测系统是一种创新的医疗辅助工具&#xff0c;旨在通过先进的计算机视觉技术提高阿尔兹海默症的早期诊断和病情监测效率。阿尔兹海默症是一种渐进性的神经退行性疾病&#xff0c;通常表现为认知障碍、记忆丧失和语言障碍等症状…...

玩转Docker | 使用Docker部署httpd服务

玩转Docker | 使用Docker部署httpd服务 前言一、准备工作环境确认检查操作系统准备网站目录和配置文件二、拉取httpd镜像三、运行httpd容器运行容器命令检查容器状态四、验证httpd服务浏览器访问测试错误排查五、容器管理与维护查看容器状态停止和启动容器更新网站内容和配置六…...

力扣1022. 从根到叶的二进制数之和(二叉树的遍历思想解决)

Problem: 1022. 从根到叶的二进制数之和 文章目录 题目描述思路复杂度Code 题目描述 思路 遍历思想(利用二叉树的先序遍历) 1.在先序遍历的过程中&#xff0c;用一个变量path记录并更新其经过的路径上的值&#xff0c;当遇到根节点时再将其加到结果值res上&#xff1b; 2.该题…...

排序算法--基数排序

核心思想是按位排序&#xff08;低位到高位&#xff09;。适用于定长的整数或字符串&#xff0c;如例如&#xff1a;手机号、身份证号排序。按数据的每一位从低位到高位&#xff08;或相反&#xff09;依次排序&#xff0c;每次排序使用稳定的算法&#xff08;如计数排序&#…...

【AIGC魔童】DeepSeek核心创新技术(二):MLA

【AIGC魔童】DeepSeek核心创新技术&#xff08;二&#xff09;&#xff1a;MLA 1. MLA框架的定义与背景2. MLA框架的技术原理&#xff08;1&#xff09;低秩联合压缩&#xff08;2&#xff09;查询的低秩压缩&#xff08;3&#xff09;旋转位置嵌入&#xff08;RoPE&#xff09…...