有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

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) 个答案

  1. # 1 楼答案

    如果有日志,请检查日志,否则请添加logback,这样您就有了日志

    我注意到了几件事:

    • 从Tomcat starter和Tomcat embed jasper中删除<scope>provided</scope>,这是编译范围所必需的

    • 从Spring依赖项中删除版本号,父级将提供版本

    • Tomcat无法处理jsps in runnable jar。阅读“可执行战争”(你需要战争包装)