2011-12-20 21 views
10

He creado la aplicación MVC.Spring MVC - incluye archivos estáticos/javascript, css

Quiero incluir el archivo js o css en jsp.

Mis archivos estáticos ar en:

 
- webapp 
     -js/jquery.js 
     -WEB-INF| 
       | 
       - jsp/*.jsp 

Mi código para incluir jQuery es:

<script type="text/javascript" src="<c:url value="js/jquery.js" />"></script> 

y no puedo cargar el archivo js a la vista.

que ver con los registros de información:

WARN : org.springframework.web.servlet.PageNotFound - No mapping found for HTTP request with URI [/pool/js/jquery.js] in DispatcherServlet with name 'appServlet' 

lo que significa, que MVC intenta asignar url para js.

Creo que hay algo en mi configuración, pero no sé qué.

mi web.xml es:

<?xml version="1.0" encoding="UTF-8"?> 

http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd ">

<!-- 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</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> 

    <filter> 
    <filter-name>hibernateFilter</filter-name> 
    <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class> 
    </filter> 
    <filter-mapping> 
    <filter-name>hibernateFilter</filter-name> 
    <url-pattern>/*</url-pattern> 
    </filter-mapping> 

+0

Ver: http://stackoverflow.com/questions/10495571/spring-not-finding-resource-files-css-jsp – ALOToverflow

Respuesta

6

cambie la asignación de DispatcherServlet a por ejemplo:

<servlet-mapping> 
    <servlet-name>appServlet</servlet-name> 
    <url-pattern>*.jsp</url-pattern> 
</servlet-mapping> 

O alguna otra no conflictiva url-pattern como *.htm o /controllers/*. Recuerde que a partir de ahora todos sus controladores estarán disponibles solo a través de este patrón.

Ahora se está interceptando todo en su aplicación web, incluyendo .js archivos, imágenes, etc.

Lo mismo con hibernateFilter - que realmente no necesita una sesión de Hibernate abierta al recoger .js archivos, no se ¿tú?

+0

pero, cuando hago esto, mi asignación real se destruye. Después de cambiar mi url: http: // localhost: 8080/pool/main no funciona – Ilkar

+0

One chenge: he agregado otro servlet-mapping con * .js – Ilkar

0

etiquetas JSTL Uso de primavera para incluir archivos de script externos u hojas de estilo. Primero debe incluir el taglib en JSP de la siguiente manera.

<%@ taglib uri="http://www.springframework.org/tags" prefix="spring"%> 

A continuación, se pueden incluir archivo de script utilizando extenal,

<script type="text/javascript" src="<spring:url value="/js/jquery.js"/>"></script> 
0

Estoy de acuerdo con su respuesta. Pero en el archivo style.css declara url que se relaciona con la ruta de la imagen.

--style.css--

.cwt-object0 
{ 
    display: block; 
    left: 2.62%; 
    margin-left: -1px; 
    position: absolute; 
    top: 43px; 
    width: 64px; 
    height: 64px; 
    background-image: url('/resources/images/object0.png'); 
    background-position: 0 0; 
    background-repeat: no-repeat; 
    z-index: 0; 
} 

Cómo utilizar la etiqueta <spring:url></spring:url> en el archivo style.css para ver en el navegador IE/Firefox

archivo --jsp ---

<link href="<spring:url value="/resources/style.css"/>" rel="stylesheet" type="text/css" media="screen"> 
2

Por qué no utilizar la sencilla jsp core?

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>  
<link rel="stylesheet" type="text/css" href="<c:url value='/resources/css/bootstrap.css'/>" /> 
+0

Solución fácil. +1 –

0

añadir mvc: recursos en el archivo de configuración (* -servlet.xml), se pueden encontrar funciona

0

acabo siguieron Mkyong Tutorial colocar CSS, JS, jQuery & archivos de imagen. Funciona para mí.

En servlet-context.xml

<!-- Handles HTTP GET requests for /resources/** by efficiently serving 
     up static resources in the ${webappRoot}/resources directory --> 
    <resources mapping="/resources/**" location="/resources/assets/" /> 

En JSP, la biblioteca de códigos de importación

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> 

y añadir como

<link rel="stylesheet" href="<c:url value='/resources/css/custom.css'/>">