【发布时间】: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.prefix和spring.mvc.view.suffix属性。 -
@AndyWilkinson 非常感谢 AndyWilkinson,你帮了我很多。我将“WebMvcConfigurationSupport”类更改为“WebMvcConfigurer”接口,然后在 application.properties 中设置 View Resolvers,它运行良好。但我确实有一个问题,我什么时候可以在新的 Spring-Boot 版本中使用“InternalResourceViewResolver”?
标签: java spring spring-boot jsp model-view-controller