什么是client路径?

第一类、也就是html或js文件等client訪问的文件里的路径,这里包含一些资源文件的引入(js、css还有各种图片等),或是跳转到静态html页面,总之获取的都是静态资源

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

事实上这两类本质都一样,都是通过请求server来获得对应的资源。

在tomcat中一般用一个defaultServlet来处理静态资源的訪问。

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

client相对路径的使用方法


第一种:相对于当前页面

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

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

事实上就是以你当前訪问的页面的地址为当前路径,你能够把它理解成一个基准路径,而src中的相对路径则是基于这个基准路径的。(貌似JSP的head里有个base标签,能够改这个基准路径。只是我没用过)

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

那js文件在server上的绝对路径就是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>

可是这种路径就和我们的WEBproject名绑定起来了,不方便移植。

事实上我们这个WEBproject名我们在程序中是能够用”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:我也是发生了这个错,才想到要记录一下的

Spring3拦截引发的问题——WEB开发中的client路径的更多相关文章

  1. Web开发中的相对路径和绝对路径

    在学习HTML的时候一定会遇到引入文件和链接跳转页面,比如:JS文件.CSS文件.Image图片.我们就会考虑是相对路径和绝对路径的问题.下面PHP程序员雷雪松就详细讲解下Web开发中的相对路径和绝对 ...

  2. SpringBoot学习(七)-->SpringBoot在web开发中的配置

    SpringBoot在web开发中的配置 Web开发的自动配置类:在Maven Dependencies-->spring-boot-1.5.2.RELEASE.jar-->org.spr ...

  3. 在 Web 开发中,img 标签用来呈现图片,而且一般来说,浏览器是会对这些图片进行缓存的。

    在 Web 开发中,img 标签用来呈现图片,而且一般来说,浏览器是会对这些图片进行缓存的. 比如访问百度,我们可以发现,图片.脚本这种都是从缓存(内存缓存/磁盘缓存)中加载的,而不是再去访问一次百度 ...

  4. 【初码干货】使用阿里云对Web开发中的资源文件进行CDN加速的深入研究和实践

    提示:阅读本文需提前了解的相关知识 1.阿里云(https://www.aliyun.com) 2.阿里云CDN(https://www.aliyun.com/product/cdn) 3.阿里云OS ...

  5. Web 开发中很实用的10个效果【附源码下载】

    在工作中,我们可能会用到各种交互效果.而这些效果在平常翻看文章的时候碰到很多,但是一时半会又想不起来在哪,所以养成知识整理的习惯是很有必要的.这篇文章给大家推荐10个在 Web 开发中很有用的效果,记 ...

  6. WEB开发中的字符集和编码

    html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,bi ...

  7. Web 开发中很实用的10个效果

    在工作中,我们可能会用到各种交互效果.而这些效果在平常翻看文章的时候碰到很多,但是一时半会又想不起来在哪,所以养成知识整理的习惯是很有必要的.这篇文章给大家推荐10个在 Web 开发中很有用的效果,记 ...

  8. Web开发中管理ipad屏幕的方向变化

    Web开发中,我们会遇到在手机垂直或水平视角时展示不同状态的情况.下面我来总结一下检测移动设备方向变化的一些方法. 1 使用javascript 直接看代码: <script type=&quo ...

  9. 今日推荐:10款在 Web 开发中很有用的占位图片服务

    设计网站时,将要使用的图像在一开始通常还不存在,这个时候布局是最重要的.然而,图像的尺寸通常是预先设置,实用一些占位图像可以帮助我们更好地预览和分析布局. 如今,有免费的占位图片自动生成工具可以使用, ...

随机推荐

  1. 【实用篇】Android之应用程序实现自动更新功能

    我个人用的是友盟提供的自动更新组件,因此在这里只描述如何实用友盟提供的组件来完成程序的自动更新,步骤如下: 1.登录友盟官网,点击注册一个友盟账号. 2.注册成功后将会自动进入到添加新应用界面,选择添 ...

  2. HDU 3374 String Proble

    String Problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  3. 关于IDEA无法完整显示项目文件结构

    今天发现一个奇怪的问题,就是我从本地导入了文件,明明已经成功了,但是在我的项目结构里面就是不显示,然而点击目录, 又能打开相应的文件,如图所示: 其实这个打开的只是包文件,只需要如下图操作即可:

  4. JS之闭包详细解读

    闭包在红宝书中的解释就是:有权访问另一个函数作用域中的变量的函数. 1.变量作用域 全局变量:所有的函数外部定义的变量,它的作用域是整个script. 局部变量:定义在函数体内部的变量,作用域仅限于函 ...

  5. Linux下QQ的使用并手动设置QQ文件保存路径

    一.背景&&目标 马化腾迟迟不肯做linux版本的QQ和微信,实在抠脚. 没有办法,要在linux上使用QQ,目前我找到最好的办法就是使用wine,然而wine这个杀千刀的又是个坑货, ...

  6. 2018上半年GitHub上最热门的开源项目

    关注GitHub的人都知道,这个平台上面有太多优秀的值得学习的开源项目了,这里总结了2018上半年GitHub上最热门的开源项目. 1: tensorflow https://github.com/t ...

  7. mysql通过字段凝视查找字段名称

    有时候表的字段太多.仅仅是大致记得表的凝视,想通过字段凝视查找字段名称,能够用例如以下语句: SELECT COLUMN_NAME,column_comment FROM INFORMATION_SC ...

  8. Linq案例

    1.牛刀小试 using System; using System.Collections.Generic; using System.Linq; using System.Text; using S ...

  9. css3新特性选择器(补充)

    1.选择p标签中的第一个字符 p:first-letter{ color:red; font-size:25px; } 2.选择p标签中的第一行 p:first-line{ color:red; fo ...

  10. 7.cocos精灵创建和绘制

    创建Layer层的类 T2LayerSprite.h #pragma once #include "cocos2d.h" USING_NS_CC; class T2LayerSpr ...