sql >> Databáze >  >> NoSQL >> MongoDB

Chyba ověření při přístupu k mongodb prostřednictvím aplikace Spring Boot

Našel jsem problém. Pro úplnost tohoto vlákna sdílím odpověď včetně kódu. Problém byl v tom, že jsem špatně použil vlastnost aplikace spring.data.mongodb.uri:neměla uživatelské jméno a heslo v URI, protože jsem omylem věřili, že uživatelské jméno a heslo spring.data.mongodb. Takže buď použijte uri s uživatelským jménem a heslem, nebo použijte vlastnosti hostitele a databáze (a možná také portu) explicitně. Zde je kód. Bude fungovat v jarní spouštěcí aplikaci s podporou mongoDB (pro vytvoření projektu použijte initializr nebo IntelliJ). Mám model:

package net.IndyStef.model;

import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;

@Document(collection = "person")
public class Person {

@Id
private String id;

private String name;
private Integer age;

public Person() {
}

public Person(String id) {
    this.id = id;
}

public Person(String id, String name, Integer age) {
    this.id = id;
    this.name = name;
    this.age = age;
}

... getters/setters omitted for breverity ...
}

Data se čtou a zapisují prostřednictvím úložiště:

package net.IndyStef.repository;

import net.okrongli.model.Person;
import org.springframework.data.mongodb.repository.MongoRepository;

/**
 * Created by IndyStef on 23/08/16.
 */
public interface PersonRepository extends MongoRepository<Person, String> {
}

Název databáze, hostitel a pověření jsou v souboru application.properties:

spring.data.mongodb.host=192.168.1.90
spring.data.mongodb.database=people
spring.data.mongodb.username=user
spring.data.mongodb.password=password
#spring.data.mongodb.uri=mongodb://192.168.1.90/people

Důležité je nesměšovat uri s databází a uživatelským jménem. Pokud používáte uri, musí obsahovat uživatelské jméno a heslo, jako je toto:

spring.data.mongodb.uri=mongodb://user:[email protected]/people

K otestování jsem použil jednoduchý příkazový řádek Spring:

package net.IndyStef;

import net.IndyStef.model.Person;
import net.IndyStef.repository.PersonRepository;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

import java.util.List;

@SpringBootApplication
public class MongoDbTestApplication implements CommandLineRunner {

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

    @Autowired
    private PersonRepository repository;

    @Override
    public void run(String... args) {

        repository.save(new Person("peter.pan", "Peter Pan", 865));

        List<Person> people = repository.findAll();

        for (Person person: people) {
            System.out.println(person);
        }
    }
}

Doufám, že toto vysvětlení pomůže ostatním, kteří na to nemohli přijít, jako jsem já několik dní.

Díky,

Stefan



  1. Jak vrátit pouze hodnotu pole v mongodb

  2. findOne funguje, ale ne dostat vše/najít

  3. Jaké je použití typu javascript/javascript s rozsahem bson

  4. Aktualizujte kolekci MongoDB pomocí $toLower