我下载了使用 css 和 JavaScript 的登录模板。当我以默认的 html 格式启动它时,它显示正常,但是当我将相同的代码放入我的 Spring MVC 3 应用程序并将格式更改为 jsp 时,javascript 部分被禁用。我可以通过我的网络浏览器访问外部 js 文件,所以我不知道问题出在哪里。
这是正确的外观:
但这就是我得到的:
<script language="javascript" type="text/javascript" src="js/niceforms.js"></script>
<link rel="stylesheet" type="text/css" media="all" href="css/niceforms-default.css" />
我只更改了外部 js 和 css 资源的位置,但正如我所说,这些文件是可以访问的。
这是我的结构:
在我的web.xml
我有这些行:
<!-- The definition of the Root Spring Container shared by all Servlets and Filters -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
/WEB-INF/spring/root-context.xml,
/WEB-INF/spring/security-context.xml,
</param-value>
</context-param>
<!-- Creates the Spring Container shared by all Servlets and Filters -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- Processes application requests -->
<servlet>
<servlet-name>appServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring/appServlet/servlet-context.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>appServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!-- Spring Security -->
<filter>
<filter-name>springSecurityFilterChain</filter-name>
<filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>
<filter-mapping>
<filter-name>springSecurityFilterChain</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.css</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.js</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.gif</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.jpg</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.png</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.txt</url-pattern>
</servlet-mapping>
我也使用 Apache tiles2
<tiles-definitions>
<definition name="base.definition" template="/WEB-INF/views/layout/layout.jsp">
<put-attribute name="body" value="" />
</definition>
<definition name="contact" extends="base.definition">
<put-attribute name="body" value="/WEB-INF/views/contact.jsp" />
</definition>
<definition name="login" template="/WEB-INF/views/login/login.jsp">
</definition>
谢谢。
编辑:
我现在知道问题出在哪里,但仍然不知道如何解决...问题出在外部 css 文件的路径中。我有这样的事情:body {background-image:url('images/bg.jpg');}
但是我在firebug中找不到错误,因为它试图在localhost:8080/sheedo/css/images/bg.jpg中找到资源,并且当我设置资源的绝对路径时,body {background-image:url('/images/bg.jpg');}
我也得到了同样的错误但它试图在localhost:8080/images/bg.jpg中找到它。当我使用./images/bg.jpg
它时没问题,但是否存在任何其他解决方案而不是重写 css 文件中的所有路径?我的意思<mvc:resources ... >
是有可能吗?