sql >> Databasteknik >  >> NoSQL >> MongoDB

Autentiseringsfel vid åtkomst till mongodb via Spring Boot-appen

Jag hittade problemet. För fullständighetens skull kommer jag att dela med mig av svaret, inklusive koden. Problemet var att jag använde applikationsegenskapen spring.data.mongodb.uri fel:den hade inte användarnamnet och lösenordet i URI:n, eftersom jag av misstag trodde att spring.data.mongodb.username och spring.data.mongodb.password täckte det. Så använd antingen uri med användarnamn och lösenord, eller använd värd- och databas- (och kanske även port) fjäderegenskaper explicit.Här är koden. Det kommer att fungera i vårstartappen med mongoDB-stöd (använd initializr eller IntelliJ för att skapa det projektet). Jag har en modell:

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 läses och skrivs genom ett arkiv:

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

Databasnamnet, värddatorn och användaruppgifterna finns i filen 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

Viktigt är att inte blanda uri med databas och användarnamn. Om du använder uri måste den inkludera användarnamn och lösenord, så här:

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

För att testa detta använde jag en enkel Spring-kommandoradskörare:

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

Jag hoppas att den här förklaringen hjälper andra som inte kunde ta reda på det, som jag själv under ett par dagar.

Tack,

Stefan



  1. NoSQL-databaser

  2. MongoDB $toLong

  3. Hur man anger läspreferens i Meteors mongo-frågor

  4. Mongodb dot notation jokertecken?