2017-08-07 1 views
0

Donc, je sais qu'il y a d'autres questions comme celle-ci mais je ne vois pas de solution à mon problème.Spring boot + MongoDB - localhost afficher l'erreur whitelabel

Espérons que l'un de vous puisse voir ce que je fais de mal.

Quand je vais à localhost //: 8080 je reçois "erreur de whitelabel ...."

Mon pom.xml ressemble à ceci:

<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> 

et ma classe d'application ressemble à ceci:

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); 
    } 
} 

Et le 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; 
    } 
} 

maintenant mon application "fonctionne" car elle enregistre de nouveaux "Fil" à mon mongoDB. Je voulais les retourner dans la fonction "Home" dans la classe Application, mais jusqu'à présent, je ne peux rien obtenir, mais "whitelabel error" out ...

Merci d'avance!

** Modifier

La structure du fichier est la suivante. enter image description here

et l'erreur complète du // localhost: 8080 est:

Whitelabel page d'erreur

Cette application n'a pas de correspondance explicite/erreur, si vous voyez cela comme une solution de repli. Mon Aug 07 16:39:18 CEST 2017 Une erreur inattendue s'est produite (type = erreur interne du serveur, état = 500). com/mongodb/BulkWriteException

+0

pouvez-vous s'il vous plaît coller le message d'erreur entier et la trace de la pile de la console. – zombie

+0

Salut @zombie, le message d'erreur est la suivante: Whitelabel Error Page Cette application n'a pas de mappage explicite pour/error, donc vous voyez cela comme un repli. Mon Aug 07 16:39:18 CEST 2017 Une erreur inattendue s'est produite (type = erreur interne du serveur, état = 500). com/mongodb/BulkWriteException mais je ne reçois aucune sortie dans la console ... Si vous savez pourquoi ce serait une aide massive! :) –

Répondre

2

On dirait qu'il est à la recherche de BulkWriteException qui est disponible à partir de version pilote 2.12 mongo.

Solution 1

Au moins mise à niveau

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

Solution 2 (mieux)

Retirer

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

et garder

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

tire dans la dépendance correcte qui est pilote 2.4.x mongo.

Solution 3 (meilleure)

Supprimer

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

et

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

ajouter

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

tire à la fois le mongo ressort compatible et mongo la dépendance qui est de 2,4. x mo pilote ngo.

+0

Si je retire le: org.mongodb mongo-java-pilote 2.11.0 Je reçois une erreur dans ma classe "connectToDB". L'erreur étant avec ces deux: import com.mongodb.Mongo; import com.mongodb.MongoClient; il est dit que le paquet com.mongodb n'existe pas –

+0

Maven dans le cadre de [spring mongo dependency] (https://github.com/spring-projects/spring-data-mongodb/blob/1.10.x/pom.xml# L32) devrait tirer dans la dépendance du pilote mongo et essayer de forcer Maven mise à jour si elle ne tire pas la dépendance. – Veeram