Servlet转发与重定向的资源路径问题解析
一. 问题引入
转发和重定向可以说是Servlet中最重要的知识点也不为过,因为它决定着整个向Servlet体系中,执行流程的问题。
转发:
request.getRequestDispatcher("/index.jsp").forward(request, response);
重定向:
response.sendRedirect("index.jsp");
相信上面两句话大家应该是再熟悉不过了,以我的习惯Servlet转发时写绝对路径,也就是转发地址用“/”开头;而重定向时通常使用的是相对路径,也就是不以“/" 开头。那Servlet中的绝对路径和相对路径具体是什么,那我们就一起来研究一下。
二. 电脑的绝对/相对路径
如何理解绝对路径与相对路径
在Windows中,以盘符开头的称为绝对路径,见下图:
、
那相对路径是什么呢?
在Linux系统中有一个工作目录的概念,所谓的工作目录就是当前用户所在的目录,那么在这里也暂且将所在目录称为工作目录。相对目录就是以当前所在目录开始计算路径值。
举个栗子:
如果用户当前这在 E:\ A目录下,那么此时 “B \ index.html”这个相对目录表示的绝对路径就是 “E:\ A \ B \ index.html”。
相对路径中的常用用法
在使用相对路径时如果想进入下一级目录可能大家清楚的很,直接在后面加斜杠然后写上目录或文件名即可。那如果我们必须进入上一级目录呢,首先明确我们在什么需求下需要进入上一级目录:
1. 获取上级目录中的文件
2. 进入当前目录的同级目录
那在相对路径的写法中,如何进入上级目录呢?
两个点代表上级目录。例如: 我们想进入当前目录的同级目录haha,我们可以这样表示“../haha”
扯得有点远了,现在我们回到正题,来讲一讲Servlet中转发和重定向时相对路径与绝对路径的使用。
三. 转发和重定向时的相对路径与绝对路径
1. 绝对路径
首先需要明确Servlet中的绝对路径到底是什么,在Servlet中转发时所代表的的绝对路径实际上就是该项目的根路径。例如:http://localhost:8080/TestWeb/。
你以为重定向时的绝对路径初始值也是当前项目根路径吗?Servlet在重定向时所代表的的绝对路径是当前Tomcat容器所在的根路径(也就是webapps)。例如:http://localhost:8080/ ,说白了就是重定向时绝对路径的初始值是没有项目名称的。
我们现在就来看一下重定向的绝对路径的效果。
Servlet代码:

访问时的URL:

回车后:

这样就会导致找不到我们项目中的index.jsp页面
解决方案:
1. 将路径写成相对路径

2. 在绝对路径前面加上项目名

绝对路径总结:在转发时绝对路径的初始值是带有项目名的,而在重定向时绝对路径的初始值是不带有项目名的。
2. 相对路径
说完绝对路径我们再来说一说相对路径,在绝对路径中重定向与转发有一定的区别,而在使用相对路径中转发与重定向没有任何区别,它们都是相对于当前所在目录来进行访问的(这句话如果看不懂就自行略过吧:这里的目录既代表WebRoot下面的真实目录,也代表Servlet配置<url-pattern>的逻辑目录。)既然重定向和转发在使用相对路径是的目录起算点是相同的,那么我们就以重定向来进行演示。

访问时的URL:

回车后的URL:

总结
在Servlet中使用绝对路径进行转发和重定向,他们的路径起算点是不相同的,转发时以项目名称作为起算点,重定向时以端口号作为起算点。而如果使用相对路径进行重定向或转发,他们都是以当前所在路径作为起算点。
Servlet转发与重定向的资源路径问题解析的更多相关文章
- servlet转发与重定向区别
servlet转发与重定向 HttpServletRequest: 表示浏览器向服务器发送的请求报文,由Tomcat创建然后作为参数传递给我们doget,dopost方法. 功能:getParam ...
- Servlet转发和重定向的区别
附上视频教学的一张图: 区别: 1.转发产生一次请求,一次响应: 重定向产生2次请求 两次响应 2.转发客户端不可见的: 重定向客户端是可以察觉的. 3.转发时候url不变: 重定向URL会改变 案例 ...
- Servlet转发到JSP页面的路径问题
一.现象与概念 1. 问题 在Servlet转发到JSP页面时,此时浏览器地址栏上显示的是Servlet的路径,而若JSP页面的超链接还是相对于该JSP页面的地址且该Servlet和该JSP页面不在同 ...
- servlet转发与重定向
HttpServletRequest: 表示浏览器向服务器发送的请求报文,由Tomcat创建然后作为参数传递给我们doget,dopost方法. 功能:getParameter()获取请求参数 get ...
- servlet转发和重定向
1 转发 RequestDispatcher getRequestDispatcher(java.lang.String path) 1)地址栏不会改变 2)转发只能转发到当前web应用内的资源 3) ...
- Servlet(四):转发与重定向、路径问题
在上次的小案例中用到了转发的技术,今天来仔细聊聊转发和重定向的问题,以及一些小知识的汇总. 一.转发 1.转发的概念 转发主要是将浏览器的请求交给另外一个servlet或jsp来处理,借助reques ...
- Servlet中转发和重定向的路径问题以及表单提交路径问题
一.请求转发与响应重定向的种类 有两种方式获得Servlet转发对象(RequestDispatcher):一种是通过HttpServletRequest的getRequestDispatcher() ...
- Servlet中转发和重定向的路径问题【转】
转发和重定向的路径问题 Servlet中有两种方式获得转发对象(RequestDispatcher):一种是通过HttpServletRequest的getRequestDispatcher()方法获 ...
- Servlet 转发请求与重定向,以及路径问题
转发请求 当一个servlet接收到请求后,如果需要将请求转发给另外一个servlet或者jsp文件,可使用下面这种方法: package cn.ganlixin.servlet; import ja ...
- servlet的转发与重定向
转发和重定向都能让浏览器获得另外一个URL所指向的资源,但两者的内部运行机制有着很大的区别. 1.转发:有两种方式获得转发对象(RequestDispatcher):一种是通过HttpServletR ...
随机推荐
- Qt获取电脑有几个网卡,并获取对应的IPV4
标题:Qt获取电脑网卡对应的ip | Qt计算电脑有几个网卡 | Qt获取网卡ip信息 | Qt判断获取到的ip是否是IPV4 demo流程: 1.点击搜索网卡按钮,搜索电脑所有的网卡,将网卡名称 ...
- 使用 Grafana 统一监控展示-对接 Zabbix
概述 在某些情况下,Metrics 监控的 2 大顶流: Zabbix: 用于非容器的虚拟机环境 Prometheus: 用于容器的云原生环境 是共存的.但是在这种情况下,统一监控展示就不太方便,本文 ...
- Cert Manager 申请SSL证书流程及相关概念-二
中英文对照表 英文 英文 - K8S CRD 中文 备注 certificates Certificate 证书 certificates.cert-manager.io/v1 certificate ...
- 在python中实现二叉树
二叉树设计 定义节点类 class Node: # 修改初始化方法 def init(self,value): self.value = value # 节点值 self.left = None # ...
- UML 哲学之道——启航篇[一]
前言 简单去介绍一下uml的哲学之道也是自我整理之道. 正文 什么是uml,全程是统一建模语言(unified modeling language),简单的说就是用图形来表示文档. 是描述构造和文档化 ...
- nginx重新整理——————nginx 模块[十]
前言 简单介绍一下nginx的模块. 正文 https://nginx.org/en/docs/ 这里面可以看到官方模块. 比如打开这个模块: https://nginx.org/en/docs/ht ...
- 重新点亮linux 命令树————守护进程[二十三]
前言 简单整理一下守护进程. 正文 守护进程一般是开机启动的. 使用nohup 与 & 符号配合运行一个命令 nohup命令使进程忽略hangup(挂起)信号 使用tail 查看log文件. ...
- 使用 Flink Hudi 构建流式数据湖
简介: 本文介绍了 Flink Hudi 通过流计算对原有基于 mini-batch 的增量计算模型的不断优化演进. 本文介绍了 Flink Hudi 通过流计算对原有基于 mini-batch 的 ...
- WPF 应用启动过程同时启动多个 UI 线程且访问 ContentPresenter 可能让多个 UI 线程互等
在应用启动过程里,除了主 UI 线程之外,如果还多启动了新的 UI 线程,且此新的 UI 线程碰到 ContentPresenter 类型,那么将可能存在让新的 UI 线程和主 UI 线程互等.这是多 ...
- pod QoS等级(A)
一.了解Pod Qos等级 一个节点不一定能提供所有pod所指定的资源limits之和那么多的资源量. 假设有两个pod,pod A使用了节点内存的 90%,pod B突然需要比之前更多的内存,这时节 ...