JSP中引入CSS后,关于CSS中图片路径的问题
我有一个JSP文件如下:
<%@ page contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" errorPage="" %>
.content { height:500px; /* 使用相对路径,直接访问JSP没问题,通过Servlet的forward有问题 */ /*background:url(resources/images/homeModel.gif);*/ /* 使用绝对路径后,Servlet的forward也无问题 */ background:url(<%=request.getContextPath()%>/resources/images/homeModel.gif); }
文件中通过link引入了一个外部的CSS文件。
如果我直接访问JSP的话,这个文件中的 background:url(../resources/images/model1.jpg); 属性没问题;
但是我通过Servlet的forward转发后,环境的上下文就发生了改变,像这样使用相对路径就无法访问到图片,虽然可以改用绝对路径解决。
但是,这样做就把整个路径写死了,由于项目名称http://ip:port/project 有可能发生改变,所以不希望使用写死的绝对路径。
如果这个css样式在jsp文件中,还好说,直接通过request.getContextPath()方法就可以等到上下文。但是外部的CSS文件无法使用这种方式。
我又不可能把所有的css都写在jsp页面中,对于JSP中引入外部CSS或者JS文件的情况,如何解决文件路径的问题的?
所以,想求一个方案,如何来实现这种css文件中的路径问题?
不知道大家在遇到这种问题的时候一般都是采取的什么方案?
我的web目录结构是:
http://localhost:8080/project/
/project 是项目的根目录,也就是request.getContextPath()得到的内容
下面是项目整体的目录结构:
project
- css home.css
- js home.js
- resources
- images
- 所有图片都存放在此
- css
- js