2011-12-20 15 views
10

Ho creato un'applicazione MVC.Spring MVC: include file statici/javascript, css

Voglio includere js o css file in jsp.

I miei file statici ar sotto:

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

Il mio codice per includere jQuery è:

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

e non posso caricare il file js in vista.

vedo i log con info:

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

cosa significa, che MVC cercano di mappare url del file js.

Penso che ci sia qualcosa con la mia configurazione, ma non so cosa.

mio web.xml è:

<?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

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

risposta

6

Cambiare la mappatura DispatcherServlet per esempio:

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

O altri non contrastanti url-pattern come *.htm o /controllers/*. Ricorda che d'ora in poi tutti i tuoi controller saranno disponibili solo attraverso questo schema.

Ora sta intercettando tutto nella vostra applicazione web, tra cui .js file, immagini, ecc

la stessa cosa con hibernateFilter - non si ha realmente bisogno di una sessione di Hibernate aperta quando il recupero .js file, non lo fanno tu?

+0

ma, quando lo faccio, la mia mappatura effettiva viene distrutta. Dopo aver cambiato il mio URL: http: // localhost: 8080/pool/main non funziona – Ilkar

+0

One chenge - ho aggiunto un altro servlet-mapping con * .js – Ilkar

0

tag Usa primavera JSTL per includere file di script esterni o fogli di stile. Innanzitutto dovresti includere il taglib in JSP come segue.

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

Quindi è possibile includere file di script utilizzando extenal,

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

Sono d'accordo con la tua risposta. Ma nel file style.css dichiarare url che si riferiscono al percorso dell'immagine.

- stile.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; 
} 

Come usare tag <spring:url></spring:url> nel file style.css vedere nel browser IE/Firefox

file di --jsp ---

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

Perché non utilizzare il semplice nucleo jsp?

<%@ 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

Soluzione facile. +1 –

0

aggiungere MVC: risorse nel file di configurazione (* -servlet.xml), lo si può trovare funziona

0

Ho appena seguito Mkyong Tutorial di inserire il CSS, JS, jQuery & file di immagine. Funziona per me.

In 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/" /> 

In JSP, l'importazione libreria di tag

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

e aggiungere come

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