【问题标题】:Spring boot does not render JSP pages, Spring boot new Versions (2.5.0)Spring boot 不渲染 JSP 页面,Spring boot 新版本(2.5.0)
【发布时间】:2021-08-31 23:03:35
【问题描述】:

当我使用 Spring Boot 2.1.8 Release 运行旧项目时,它运行良好并且所有 JSP 文件都正确显示,但最近我创建了一个新项目并使用 2.5.0 Release(WAR、Java 11、 嵌入式Tomcat)。它不呈现 JSP 文件,也不显示错误消息!

ApplicationConfig.java

@Configuration
@ComponentScan(basePackages = "school.com.my.myschool")
public class ApplicationConfig extends WebMvcConfigurationSupport {

@Override
protected void addResourceHandlers(ResourceHandlerRegistry registry){
    registry.addResourceHandler("css/**", "images/**")
            .addResourceLocations("classpath:static/css/", "classpath:static/images/");
}


@Bean
InternalResourceViewResolver jspViewResolver(){
    InternalResourceViewResolver viewResolver = new InternalResourceViewResolver();
    viewResolver.setPrefix("/WEB-INF/jsp");
    viewResolver.setSuffix(".jsp");
    viewResolver.setViewClass(JstlView.class);
    return viewResolver;
}
}

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven- 
4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.5.0</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>school.com.my</groupId>
<artifactId>myschool</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<name>myschool</name>
<description>Demo project for Spring Boot</description>

<properties>
    <java.version>1.8</java.version>
</properties>
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <scope>runtime</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-tomcat</artifactId>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
         <artifactId>jstl</artifactId>
    </dependency>
    <dependency>
        <groupId>org.apache.tomcat.embed</groupId>
        <artifactId>tomcat-embed-jasper</artifactId>
        <scope>provided</scope>
    </dependency>
</dependencies>

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>

</project>

HomeController

@Controller
public class HomeController {

@GetMapping("/home")
public String toHome(){
    System.out.println("In Home Controller!");
    return "index";
}
}

我运行它为 -> Maven - 插件 - spring-boot - spring-boot-run

当我运行 http://localhost:8080/home

虽然标签错误页面出现意外错误(类型=未找到,状态=404)

但在控制台中 ->

2021-06-16 12:48:22.087  INFO 4136 --- [           main] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Start completed.
2021-06-16 12:48:22.571  INFO 4136 --- [           main] org.hibernate.dialect.Dialect            : HHH000400: Using dialect: org.hibernate.dialect.MySQL8Dialect
2021-06-16 12:48:25.499  INFO 4136 --- [           main] o.h.e.t.j.p.i.JtaPlatformInitiator       : HHH000490: Using JtaPlatform implementation: [org.hibernate.engine.transaction.jta.platform.internal.NoJtaPlatform]
2021-06-16 12:48:25.605  INFO 4136 --- [           main] j.LocalContainerEntityManagerFactoryBean : Initialized JPA EntityManagerFactory for persistence unit 'default'
2021-06-16 12:48:27.857  WARN 4136 --- [           main] JpaBaseConfiguration$JpaWebConfiguration : spring.jpa.open-in-view is enabled by default. Therefore, database queries may be performed during view rendering. Explicitly configure spring.jpa.open-in-view to disable this warning
2021-06-16 12:48:29.852  INFO 4136 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8080 (http) with context path ''
2021-06-16 12:48:29.933  INFO 4136 --- [           main] s.com.my.myschool.MyschoolApplication    : Started MyschoolApplication in 38.136 seconds (JVM running for 41.125)
2021-06-16 12:48:29.939  INFO 4136 --- [           main] o.s.b.a.ApplicationAvailabilityBean      : Application availability state LivenessState changed to CORRECT
2021-06-16 12:48:29.950  INFO 4136 --- [           main] o.s.b.a.ApplicationAvailabilityBean      : Application availability state ReadinessState changed to ACCEPTING_TRAFFIC
2021-06-16 12:48:37.223  INFO 4136 --- [nio-8080-exec-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring DispatcherServlet 'dispatcherServlet'
2021-06-16 12:48:37.224  INFO 4136 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2021-06-16 12:48:37.232  INFO 4136 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet        : Completed initialization in 8 ms
In Home Controller!

文件夹结构

有什么想法吗?

【问题讨论】:

  • 你能分享你的文件夹结构吗?
  • @kameshsr 刚刚添加了它
  • 通过子类化WebMvcConfigurationSupport,你告诉 Spring Boot 你想完全控制 Spring MVC 的配置,这样 Spring Boot 的自动配置就会退出。这不太可能是你想要的。一般来说,你应该实现WebMvcConfigurer。实际上,您复制了 Boot 将为您执行的部分操作,因此我将完全删除代码并设置 spring.mvc.view.prefixspring.mvc.view.suffix 属性。
  • @AndyWilkinson 非常感谢 AndyWilkinson,你帮了我很多。我将“WebMvcConfigurationSupport”类更改为“WebMvcConfigurer”接口,然后在 application.properties 中设置 View Resolvers,它运行良好。但我确实有一个问题,我什么时候可以在新的 Spring-Boot 版本中使用“InternalResourceViewResolver”?

标签: java spring spring-boot jsp model-view-controller


【解决方案1】:

由“tomcat”运行。

我认为您在 IDEA 中运行了“Spring Boot 应用程序”。

我和你一样失败了。

【讨论】:

  • 是的,我使用 Intellij IDEA 和嵌入式 Tomcat。但是在评论部分,@AndyWilkinson 解决了这个问题。你的问题解决了吗?
  • 是的,我解决了。谢谢你的关心:)