java Spring启动运行良好,但不是它的Jar?
我使用内存中的H2数据库构建了这个应用程序
如果我运行mvn spring boot:run它会在端口8081上启动Tomcat,我可以使用urllocalhost:8081/Patients很好,并且能够与数据库交互
如果我运行mvn package,然后运行java-jar来自/target的jar文件,它会在端口8081上启动Tomcat,上面的url返回404。显示的消息似乎没有找到资源,这是一个jsp文件
There was an unexpected error (type=Not Found, status=404).
/Patients/WEB-INF/views/patient/welcome.jsp
我正试图构建这个应用程序,可以在它的基础上生存,但不确定我错过了什么
波姆。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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>Paulo</groupId>
<artifactId>Patients</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>Patients</name>
<description></description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.9.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<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>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>4.3.11.Final</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-entitymanager</artifactId>
<version>4.3.11.Final</version>
</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>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
<resources>
<resource>
<directory>src</directory>
</resource>
</resources>
</build>
</project>
应用属性
#spring.datasource.url = jdbc:mysql://localhost:3306/pauloaraujo?createDatabaseIfNotExist=true
#spring.datasource.driverClassName=com.mysql.jdbc.Driver
#spring.datasource.username = root
#spring.datasource.password = pauloaraujo
jdbc.driverClassName=org.h2.Driver
jdbc.url=jdbc:h2:mem:myDb;DB_CLOSE_DELAY=-1
server.port=8081
server.contextPath=/Patients
# Show or not log for each sql query
spring.jpa.show-sql = true
# Hibernate ddl auto (create, create-drop, update)
spring.jpa.hibernate.ddl-auto = create
# Naming strategy
spring.jpa.hibernate.naming-strategy = org.hibernate.cfg.ImprovedNamingStrategy
# Use spring.jpa.properties.* for Hibernate native properties (the prefix is
# stripped before adding them to the entity manager)
# The SQL dialect makes Hibernate generate better SQL for the chosen database
spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect
spring.mvc.view.prefix: /WEB-INF/views/
spring.mvc.view.suffix: .jsp
编辑:
我了解到Tomcat不会将可执行JAR与JSP一起交付,然后我将包装更改为WAR
我运行了java-jar-mywar。war结果是Tomcat位于8080端口,消息为
There was an unexpected error (type=Not Found, status=404).
No message available
# 1 楼答案
如果有日志,请检查日志,否则请添加logback,这样您就有了日志
我注意到了几件事:
从Tomcat starter和Tomcat embed jasper中删除
<scope>provided</scope>
,这是编译范围所必需的从Spring依赖项中删除版本号,父级将提供版本
Tomcat无法处理jsps in runnable jar。阅读“可执行战争”(你需要战争包装)