Spring boot + MongoDB - localhost show whitelabel error

问题描述:

所以我知道还有其他问题,比如这个,但是我没有看到我的问题的解决方案。Spring boot + MongoDB - localhost show whitelabel error

希望你们其中一个能看到我做错了什么。

当我去到localhost //:8080我得到 “白色标签错误......”

我的pom.xml看起来是这样的:

<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>com.mycompany</groupId> 
    <artifactId>mavenproject1</artifactId> 
    <version>1.0-SNAPSHOT</version> 
    <packaging>war</packaging> 

    <name>mavenproject1</name> 

    <parent> 
     <groupId>org.springframework.boot</groupId> 
     <artifactId>spring-boot-starter-parent</artifactId> 
     <version>1.5.6.RELEASE</version> 
    </parent> 

    <properties> 
     <endorsed.dir>${project.build.directory}/endorsed</endorsed.dir> 
     <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 
    </properties> 

    <dependencies> 
     <dependency> 
      <groupId>javax</groupId> 
      <artifactId>javaee-web-api</artifactId> 
      <version>7.0</version> 
      <scope>provided</scope> 
     </dependency> 
     <!--Spring--> 
     <dependency> 
      <groupId>org.springframework.boot</groupId> 
      <artifactId>spring-boot-starter-web</artifactId> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-core</artifactId> 
      <version>4.3.10.RELEASE</version> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework</groupId> 
      <artifactId>spring-context</artifactId> 
      <version>4.3.10.RELEASE</version> 
     </dependency> 
     <!--MONGO--> 
     <dependency> 
      <groupId>org.mongodb</groupId> 
      <artifactId>mongo-java-driver</artifactId> 
      <version>2.11.0</version> 
     </dependency> 
     <dependency> 
      <groupId>org.springframework.data</groupId> 
      <artifactId>spring-data-mongodb</artifactId> 
      <version>1.10.6.RELEASE</version> 
     </dependency> 
     <dependency> 
      <groupId>cglib</groupId> 
      <artifactId>cglib</artifactId> 
      <version>2.2.2</version> 
     </dependency> 
     <dependency> 
      <groupId>org.elasticsearch</groupId> 
      <artifactId>elasticsearch</artifactId> 
      <version>2.4.0</version> 
     </dependency> 
    </dependencies> 

    <build> 
     <plugins>   
      <plugin> 
       <artifactId>maven-compiler-plugin</artifactId> 
       <version>3.0</version> 
       <configuration> 
        <source>1.8</source> 
        <target>1.8</target> 
       </configuration> 
      </plugin> 
      <plugin> 
       <groupId>org.apache.maven.plugins</groupId> 
       <artifactId>maven-eclipse-plugin</artifactId> 
       <version>2.9</version> 
       <configuration> 
        <downloadSources>true</downloadSources> 
        <downloadJavadocs>true</downloadJavadocs> 
       </configuration> 
      </plugin> 
      <!--skal dette bruges?--> 
      <plugin> 
       <groupId>org.apache.maven.plugins</groupId> 
       <artifactId>maven-war-plugin</artifactId> 
       <version>2.1.1</version> 
       <configuration> 
        <failOnMissingWebXml>false</failOnMissingWebXml> 
       </configuration> 
      </plugin> 
      <plugin> 
       <groupId>org.apache.maven.plugins</groupId> 
       <artifactId>maven-dependency-plugin</artifactId> 
       <version>2.1</version> 
       <executions> 
        <execution> 
         <phase>validate</phase> 
         <goals> 
          <goal>copy</goal> 
         </goals> 
         <configuration> 
          <outputDirectory>${endorsed.dir}</outputDirectory> 
          <silent>true</silent> 
          <artifactItems> 
           <artifactItem> 
            <groupId>javax</groupId> 
            <artifactId>javaee-endorsed-api</artifactId> 
            <version>6.0</version> 
            <type>jar</type> 
           </artifactItem> 
          </artifactItems> 
         </configuration> 
        </execution> 
       </executions> 
      </plugin> 
     </plugins> 
    </build> 

</project> 

和我的应用程序类看起来像这样:

package com.example.mavenproject1; 

import org.springframework.boot.*; 
import org.springframework.boot.autoconfigure.*; 
import org.springframework.context.annotation.ComponentScan; 
import org.springframework.stereotype.*; 
import org.springframework.web.bind.annotation.*; 

/** 
* 
* @author Steffen 
*/ 
@RestController 
@EnableAutoConfiguration 
@ComponentScan 
public class Application { 

    //Run a function here which dives into the mongoDB and returns the info? 
    @RequestMapping("/") 
    String home() { 

     DBPopulator dbp = new DBPopulator(); 

     dbp.saveNew(); 


//  return dbp.getFil(); 

     return "Hey wassup"; 
    } 

    public static void main(String[] args) { 
     SpringApplication.run(Application.class, args); 
    } 
} 

而且DBPopulator:

package com.example.mavenproject1; 

import java.util.Date; 
import java.util.List; 

import org.springframework.context.ApplicationContext; 
import org.springframework.context.annotation.AnnotationConfigApplicationContext; 
import org.springframework.data.mongodb.core.MongoOperations; 
import org.springframework.data.mongodb.core.query.Criteria; 
import org.springframework.data.mongodb.core.query.Query; 
import org.springframework.data.mongodb.core.query.Update; 


import org.springframework.context.support.GenericXmlApplicationContext; 


/** 
* 
* @author Steffen 
*/ 
public class DBPopulator { 

    ApplicationContext ctx = new AnnotationConfigApplicationContext(ConnectToDB.class); 
    MongoOperations mongoOperation = (MongoOperations) ctx.getBean("mongoTemplate"); 

    private int vers = 0; 

    public void saveNew() { 
     Fil f = new Fil("fil" + vers + "", new MetaData(new Date(), new Date(), 5)); 
     vers++; 
     mongoOperation.save(f); 
    }; 

    public String getFil(){ 
    // query to search user 
     Query searchQuery = new Query(Criteria.where("filNavn").is("fil1")); 

     Fil savedF = mongoOperation.findOne(searchQuery, Fil.class); 

     List<Fil> listFiler = mongoOperation.findAll(Fil.class); 



     System.out.println("Here is my file: " + savedF); 

     return "File: " + savedF; 
    } 
} 

现在我的应用程序“有效”,因为它为我的mongoDB保存了新的“Fil”。我想,在“主页”功能返回他们在应用类,但到目前为止,我不能得到任何东西,但“白色标签错误”了......

提前感谢!

**编辑

文件结构如下。 enter image description here

,并从本地主机//完整的错误:8080:

白色标签错误页面

该应用对/错误没有明确的映射,所以你看到这个作为后备。 周一8月07 16点39分十八秒CEST 2017年 有意外的错误(类型=内部服务器错误,状态= 500)。 com/mongodb/BulkWriteException

+0

请问您可以从控制台粘贴整个错误消息和堆栈跟踪。 – zombie

+0

嗨@zombie,错误消息如下: 白标签错误页面 此应用程序没有显式映射/错误,所以您将此视为后备。 Mon Aug 07 16:39:18 CEST 2017 出现意外错误(type = Internal Server Error,status = 500)。 com/mongodb/BulkWriteException 但我没有在控制台中得到任何输出...如果你知道为什么这将是一个巨大的帮助! :) –

看起来像它正在寻找BulkWriteException这是从2.12 mongo驱动程序版本可用。

解决方案1 ​​

至少升级到

<dependency> 
     <groupId>org.mongodb</groupId> 
     <artifactId>mongo-java-driver</artifactId> 
     <version>2.12.0</version> 
</dependency> 

方案2(好)

删除

<dependency> 
     <groupId>org.mongodb</groupId> 
     <artifactId>mongo-java-driver</artifactId> 
     <version>2.11.0</version> 
</dependency> 

,并保持

<dependency> 
    <groupId>org.springframework.data</groupId> 
    <artifactId>spring-data-mongodb</artifactId> 
    <version>1.10.6.RELEASE</version> 
</dependency> 

拉在正确的依赖是2.4.x的蒙戈的驱动程序。

溶液3(最好)

删除

<dependency> 
     <groupId>org.mongodb</groupId> 
     <artifactId>mongo-java-driver</artifactId> 
     <version>2.11.0</version> 
</dependency> 

<dependency> 
    <groupId>org.springframework.data</groupId> 
    <artifactId>spring-data-mongodb</artifactId> 
    <version>1.10.6.RELEASE</version> 
</dependency> 

添加

<dependency> 
     <groupId>org.springframework.boot</groupId> 
     <artifactId>spring-boot-starter-data-mongodb</artifactId> 
</dependency> 

拉两者兼容弹簧蒙戈和MONGO依赖其是2.4。 x mo ngo司机。

+0

如果我删除: org.mongodb蒙戈的Java驱动程序 2.11.0 我在 “connectToDB” 类得到一个错误。这两个错误是:import com.mongodb.Mongo; import com.mongodb.MongoClient;它说包com.mongodb不存在 –

+0

Maven作为[spring mongo dependency]的一部分(https://github.com/spring-projects/spring-data-mongodb/blob/1.10.x/pom.xml# L32)应该拉入mongo驱动程序依赖关系,如果不拉动依赖关系,则尝试强制更新Maven。 – Veeram