javaWeb项目中的路径格式 请求url地址 客户端路径 服务端路径 url-pattern 路径 获取资源路径 地址 url

javaweb项目中有很多场景的路径 客户端的POST/GET请求,服务器的请求转发,资源获取需要设置路径等 这些路径表达的含义都有不同,所以想要更好的书写规范有用的路径代码 需要对路径有一个清晰地认知

路径基本上分三类

  • 客户端路径
  • 服务端路径
  • 其他

路径相关的操作类型

  • 超链接
  • 表单
  • 重定向
  • 转发
  • 包含
  • <url-pattern>
  • ServletContext获取资源
  • Class获取资源
  • ClassLoader获取资源

客户端路径

超链接/表单/重定向   都是客户端路径

客户端路径形式上可以分为三种方式

  • 绝对路径;
  • 以“/”开头的相对路径;
  • 不以“/”开头的相对路径;

超链接/表单

比如:

http://127.0.0.1:8080/servlet/NewFile.jsp

绝对路径:
<a href="http://127.0.0.1:8080/servlet/ServletA">链接1</a> 

以“/”开头的相对路径:
<a href="/servlet/ServletB">链接2</a> 

相对路径:
<a href="ServletB">链接3</a>
<hr />

绝对路径:
<form action="http://127.0.0.1:8080/servlet/ServletA">
<input type="submit" value="表单1" />
</form>

以“/”开头的相对路径:
<form action="/servlet/ServletB">
<input type="submit" value="表单2" />
</form>

相对路径:
<form action="ServletB">
<input type="submit" value="表单3" />
</form>

链接1和表单1:没什么可说的,它使用绝对路径;

链接2和表单2:以“/”开头,相对主机,与当前jsp页面的主机相同

即最终访问的页面为http://localhost:8080/servlet/ServletB;

链接3和表单3:不以“/”开头,相对当前页面的路径,即页面jsp所有的路径

即最终访问的路径为:http://localhost:8080/servlet/ServletB;

重定向

两种形式

带/开头的  相对路径

不带/开头的 相对路径

ServletA中

response.sendRedirect("/servlet/ServletB");

http://127.0.0.1:8080/servlet/ServletA

因为路径以“/”开头,所以相对当前主机

http://127.0.0.1:8080/servlet/ServletB

ServletA中

response.sendRedirect("ServletB");

相对于当前ServletA的路径

当前ServletA的路径为http://127.0.0.1:8080/servlet/

所以请求的是:

http://127.0.0.1:8080/servlet/ServletB

上面的例子如果写成  

response.sendRedirect("/ServletB");

将是相对于主机http://127.0.0.1:8080/ServletB   就找不到了

强烈建议使用“/”开头的路径,这说明在页面中的超链接和表单都要以“/”开头

后面是当前应用的名称,再是访问路径

/servlet/ServletB

在Servlet中的重定向也建议使用“/”开头,同理,也要给出应用的名称

应用名称可以使用request.getContextPath()获取

response.sendRedirect(request.getContextPath() + "/BServlet");

服务端路径

请求转发 请求

服务器端路径必须是相对路径,不能是绝对路径。但相对路径有两种形式

以“/”开头;

不以“/”开头;

其中请求转发、请求包含都是服务器端路径request.getRequestDispatcher()的参数

服务器端路径与客户端路径的区别是:

  • 客户端路径以“/”开头:相对当前主机;
  • 服务器端路径以“/”开头:相对当前应用;

例如

ServletA中

request.getRequestDispatcher("/BServlet").forward(request, response);

相对于ServletA      http://127.0.0.1:8080/servlet/ServletA  的当前应用   http://127.0.0.1:8080/servlet

也就是http://127.0.0.1:8080/servlet/BServlet

如果是

request.getRequestDispatcher("BServlet").forward(request, response);

那么则是相对于当前路径 

相对于ServletA      http://127.0.0.1:8080/servlet/ServletA  的当前路径   http://127.0.0.1:8080/servlet/

也就是http://127.0.0.1:8080/servlet/BServlet

例子不是很明显,因为只有一层路径,应用名下面就是ServletB了  可以再多加一层路径尝试

比如:

假设访问AServlet的路径为:http://localhost:8080/hello/servlet/AServlet

因为路径不以“/”开头,所以相对当前应用,即http://localhost:8080/hello/servlet/BServlet。


其他

url-pattern

<url-pattern>必须使用“/”开头,并且相对的是当前应用。

ServletContext获取资源

必须是相对路径,可以“/”开头,也可以不使用“/”开头,但无论是否使用“/”开头都是相对当前应用路径

String path1 = this.getServletContext().getRealPath("a.txt");
String path2 = this.getServletContext().getRealPath("/a.txt");

path1和path2是相同的结果

Class获取资源

import java.io.InputStream;
public class Demo {
public void fun1() {
  InputStream in = Demo.class.getResourceAsStream("/a.txt");
}

public void fun2() {
  InputStream in = Demo.class.getResourceAsStream("a.txt");
}
}

其中fun1()方法获取资源时以“/”开头,那么相对的是当前类路径,即   /应用名/WEB-INF/classes/a.txt文件;

其中fun2()方法获取资源时没有以“/”开头,那么相对当前Demo.class所在路径,

因为Demo类在com.test 包下,所以资源路径为:/应用名/WEB-INF/classes/com/test/a.txt

Class获取资源也必须是相对路径,可以“/”开头,也可以不使用“/”开头。

以“/”开头,那么相对的是当前类路径,即  /应用名/WEB-INF/classes/

没有以“/”开头,那么相对当前.class所在路径,因为类一般都在包下面比如com.demo

所以/应用名/WEB-INF/classes/...包路径.../

ClassLoader获取资源

ClassLoader获取资源也必须是相对路径,可以“/”开头,也可以不使用“/”开头。

但无论是否以“/”开头,资源都是相对当前类路径。

public class Demo {
public void fun1() {
InputStream in = Demo.class.getClassLoader().getResourceAsStream("/a.txt");
}

public void fun2() {
InputStream in = Demo.class.getClassLoader().getResourceAsStream("a.txt");
}
}

fun1()和fun2()方法的资源都是相对类路径,即classes目录,即/应用名/WEB-INF/classes/a.txt

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏前端菜鸟变老鸟

ESLint报错解决方案(error: No ESLint configuration found)

在项目部署中出现报错error: No ESLint configuration found,编辑器vscode。

1.5K20
来自专栏架构说

关于 liunx select/recv函数返回值理解

今天遇到下面问题 如果socket客户端进程挂点 或者正常close 服务端检测 select检测返回的是0 还是-1 还是大于1呀 这个基本问题 竟然我分...

44750
来自专栏FreeBuf

Cookiel劫持测试工具 – Cookie Injecting Tools

Cookie Injecting Tools 是一款简单的开源cookie利用工具,是Chrome浏览器上开发的一个扩展插件,能够灵活地进行SQL注入测试,编辑...

27770
来自专栏web前端

myEclipse6.5与数据库(SQL Server2008)连接遇到的问题<用SSH框架的时候,用servlet+javabean+jsp的时候>

昨天因为学习SSH框架的搭建,时隔一年又重新遇到了myEclipse连接数据库的问题。废话不多说,上干货 (以下全部按照我遇到的问题的顺序,也就是没有顺序,就是...

23460
来自专栏信安之路

【作者投稿】十分钟带你了解XXE

关于xxe,我们首先要了解什么是xxe?XXE(XML External Entity Injection)XML外部实体注入攻击。下面就详细介绍XXE。

9000
来自专栏互联网技术杂谈

beanstalkc Tutorial 中文版

英文原版:https://github.com/earl/beanstalkc/blob/wip-doc-rtfd/doc/tutorial.rst

35780
来自专栏游戏杂谈

jscript调用bat注意事项

开发的游戏项目,需要一个工具,对指定的资源进行复制、加密,然后打包。之前打包时都手工操作,复制与加密这二步分别写了几个工具(lua加密与图片资源加密是分开的),...

10930
来自专栏Angular&服务

ionic cli的使用教程

57920
来自专栏Python中文社区

Python多进程抓取全国邮政编码和长途区号

由于Python设计的限制(就是咱们常用的CPython)最多只能用满1个CPU核心。Python提供了非常好用的多进程包multiprocessing,你只需...

28090
来自专栏SDNLAB

Ryu:模块间通信机制分析

Ryu是一款非常轻便的SDN控制器,在科研方面得到了广泛的应用。相比其他控制器,受益于Python语言,在Ryu上开发SDN应用的效率要远高于其他控制器。为了解...

35980

扫码关注云+社区

领取腾讯云代金券