Spring3拦截引发的问题——WEB开发中的客户端路径

什么是客户端路径?

第一类、也就是htmljs文件等客户端访问的文件中的路径,这里包括一些资源文件的引入(jscss还有各种图片等),或是跳转到静态html页面,总之获取的都是静态资源

第二类、指定servlet跳转路径(比如<a href=””></a>或者location.href

其实这两类本质都一样,都是通过请求服务器来获得相应的资源。在tomcat中一般用一个defaultServlet来处理静态资源的访问。

而第二类则一般是通过自己定义的<url-pattern></url-pattern>来匹配

客户端相对路径的用法


第一种:相对于当前页面

当我们在页面上使用<script type="text/javascript" src="resource/js/jquery.min.js"></script>

等来引入资源文件时,这里的resource的绝对路径到底是什么?

其实就是以你当前访问的页面的地址为当前路径,你可以把它理解成一个基准路径,而src中的相对路径则是基于这个基准路径的。(貌似JSPhead里有个base标签,可以改这个基准路径,不过我没用过)

比如你当前访问的路径为http://localhost:8080/Spring/test.htm

js文件在服务器上的绝对路径就是http://localhost:8080/Spring/resource/js/jquery.min.js

如果你的当前访问路径为http://localhost:8080/Spring/inner/test.htm

那你要引入上述文件,就需要这么写了:

<script type="text/javascript" src="../resource/js/jquery.min.js"></script>

第二种:相对于根路径

首先,我觉得在WEB应用里这应该算是绝对路径吧

在浏览器中,”/”相当于就是当前网站的根目录。比如http://192.168.0.1/

这个要和servlet中的”/”区别开来,在servlet中的”/”是WEB应用的根目录

所以刚才引入js文件还可以这么写

<script type="text/javascript" src="/Spring/resource/js/jquery.min.js"></script>

但是这样的路径就和我们的WEB工程名绑定起来了,不方便移植。

其实我们这个WEB工程名我们在程序中是可以用”request.getContextPath()”取到的

得到的contextPath前面包含”/”,所以我们在引入的时候只需要

<script type="text/javascript" src="$!path/resource/js/jquery.min.js"></script>

(这里我用的是velocity

 

另外需要说明的一点是:

Spring3中使用注解的时候,拦截路径

@RequestMapping("/test")@RequestMapping("/test/")是有区别的

第一个页面的当前路径是test的上一层,这里(可以把test想想成一个文件)

而第二个页面的当前路径则已经变成了test(可以把test想象成一个目录)

所以在写第一类相对路径的时候要注意,不然就会发生错误。

还有一个要注意:比如说用ajax请求@RequestMapping("/test/"),如果当前的目录为/test

那么不管ajax如何请求,当前路径依旧是test的上层,不会改变

 

Ps:我也是发生了这个错,才想到要记录一下的

你可能感兴趣的:(注解,spring,Web,url)