2012-03-30 10 views
6

Estoy utilizando Spring 3, configuración basada en Java, con BootStrap.Spring 3, con configuración basada en Java, y acceso de recursos problema

He descargado el programa de arranque y puse el css y js en el directorio de recursos.

El problema es que no puedo usar estos .css desde dentro de la página de freemarker. Howeve que los importé. Como estoy usando la configuración basada en Java, he añadido la "addResourceHandler" de la siguiente manera:

WebAppConfig:

@Configuration 
@EnableWebMvc 
@ComponentScan("com.springway") 
public class WebConfig implements WebApplicationInitializer { 

    @Override 
    public void onStartup(final ServletContext servletContext) throws ServletException { 
     final AnnotationConfigWebApplicationContext root = new AnnotationConfigWebApplicationContext(); 
     root.setServletContext(servletContext); 
     root.scan("com.springway"); 
     root.refresh(); 

     final ServletRegistration.Dynamic servlet = servletContext.addServlet("spring", new DispatcherServlet(root)); 
     servlet.setLoadOnStartup(1); 
     servlet.addMapping("/*"); 
    } 

    public void addResourceHandlers(ResourceHandlerRegistry registry) { 
     registry.addResourceHandler("/resources/**").addResourceLocations("/resources/"); 
    } 

registro Tomcat dice:

"ADVERTENCIA: No mapeo encontró para solicitud HTTP con el URI

[/springway/resources/css/bootstrap-responsive.css] en Dispatc herServlet con el nombre 'primavera'

Directorio:

-SpringWay 
>  -src 
>   - main 
>     -webapp 
>       -resources 
          -WEB-INF 
           -welcome.ftl 
           -springway.ftl  

welcome.ftl:

[#ftl /] 
[#include "springway.ftl" /] 


<ul class="breadcrumb"> 
    <li> 
    <a href="[@spring.url '/test'/]">Test</a> <span class="divider">/</span> 
    </li> 
    <li> 
    <a href="#">Library</a> <span class="divider">/</span> 
    </li> 
    <li class="active">Data</li> 
</ul> 

springway.ftl:

[#ftl/] 
    [#import "spring.ftl" as spring /] 

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
      "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
    <html xmlns="http://www.w3.org/1999/xhtml"> 
    <head> 

     <title> 

     </title> 

     <link href="[@spring.url '/resources/css/bootstrap-responsive.css'/]" rel="stylesheet" type="text/css" media="screen"/> 
     <link href="[@spring.url '/resources/css/bootstrap-responsive.min.css'/]" rel="stylesheet" type="text/css" media="screen"/> 
     <link href="[@spring.url '/resources/css/bootstrap.css'/]" rel="stylesheet" type="text/css" media="screen"/> 
     <link href="[@spring.url '/resources/css/bootstrap.min.css'/]" rel="stylesheet" type="text/css" media="screen"/> 

     <script src="[@spring.url '/resources/js/bootstrap.js'/]" type="text/javascript"></script> 
     <script src="[@spring.url '/resources/js/bootstrap.min.js'/]" type="text/javascript"></script> 
     </head> 

    <body ></body> 
    </html> 

Respuesta

9

Ha definido resourceLocation mal .

En lugar de

registry.addResourceHandler("/resources/**").addResourceLocations("/resources/"); 

que debería haber hecho

registry.addResourceHandler("/resources/**").addResourceLocations("/resources/**"); 

Debido a su carpeta css es la carpeta de recursos en el interior que necesita para poner el extra ** después de que el/sólo después de que se identificará la De lo contrario, se cargará solo desde las carpetas de recursos. No se considerarán las subcarpetas.

Espero que te haya ayudado.

Saludos.

+0

Gracias a Japón por su asistencia. – Echo

1

Si está usando Spring Security, es posible considerar la adición de los webjars a la lista de solicitudes autorizadas mediante la adición de esta línea de código a su SecurityConfiguration Clase:

@Configuration 
@EnableWebMvcSecurity 
public class SecurityConfiguration extends WebSecurityConfigurerAdapter { 

@Override 
protected void configure(HttpSecurity http) throws Exception { 
    http 
    .authorizeRequests() 
    .antMatchers("/resources/**", "/signup", "/about").permitAll() 
    **.antMatchers("/webjars/**").permitAll()** 
    .anyRequest().authenticated() 
    .and() 
    .formLogin().loginPage("/signin").permitAll() 
    .and() 
    .logout().permitAll(); 
} 
2

Si está usando Spring Security, es posible que considere agregar los webjars a la lista de solicitudes autorizadas agregando esta línea de código a su clase SecurityConfiguration Class:

@Configuration 
@EnableWebMvcSecurity 
public class SecurityConfiguration extends WebSecurityConfigurerAdapter { 

@Override 
protected void configure(HttpSecurity http) throws Exception { 
http 
    .authorizeRequests() 
    .antMatchers("/resources/**", "/signup", "/about").permitAll() 
    **.antMatchers("/webjars/**").permitAll()** 
    .anyRequest().authenticated() 
    .and() 
.formLogin().loginPage("/signin").permitAll() 
    .and() 
//... 
.logout().permitAll(); 
} 
Cuestiones relacionadas