MongoTemplate.getCollectionNames и MongoTemplate, метод collectionExists выдает исключение StringIndexOutOfBoundsException при подключении к Azure Cosmos DB.

Я пытаюсь получить список коллекций в базе данных. В моем приложении используется Spring-boot 2.4.1 и Azure Cosmos DB. Ниже представлен блок кода.

String uri= "mongodb://<username>:<password>@<hostname.documents.azure.com>:<port>/?ssl=true";
String dbName= "databaseName";
MongoClient mongoClient = MongoClients.create(uri);
SimpleMongoClientDatabaseFactory mongoDbFactory  = 
                 new SimpleMongoClientDatabaseFactory(mongoClient, dbName);
MongoTemplate mongoTemplate = new MongoTemplate(mongoDbFactory);
System.out.println(mongoTemplate.getCollectionNames());

Код выдает очень странный StringIndexOutOfBoundsException.

Трассировки стека:

Exception in thread "main" java.lang.StringIndexOutOfBoundsException: String index out of range: -4
    at java.lang.String.substring(String.java:1931)
    at com.mongodb.internal.operation.ListCollectionsOperation.projectFromFullNamespaceToCollectionName(ListCollectionsOperation.java:512)
    at com.mongodb.internal.operation.ListCollectionsOperation.access$1500(ListCollectionsOperation.java:86)
    at com.mongodb.internal.operation.ListCollectionsOperation$ProjectingBatchCursor.next(ListCollectionsOperation.java:418)
    at com.mongodb.client.internal.MongoBatchCursorAdapter.next(MongoBatchCursorAdapter.java:64)
    at com.mongodb.client.internal.MongoMappingCursor.next(MongoMappingCursor.java:48)
    at org.springframework.data.mongodb.core.MongoTemplate.lambda$getCollectionNames$28(MongoTemplate.java:2314)
    at org.springframework.data.mongodb.core.MongoTemplate.execute(MongoTemplate.java:535)
    at org.springframework.data.mongodb.core.MongoTemplate.getCollectionNames(MongoTemplate.java:2312)
    at TestApp.main(TestApp.java:20)

Когда я подключаюсь к экземпляру mongo, который работает на моем локальном компьютере, со строкой подключения "mongodb://localhost:27017", приведенный выше код работает нормально.

И моя соответствующая часть pom.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>
  <parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.4.1</version>
  </parent>
  <groupId>org.example</groupId>
  <artifactId>test-mongo</artifactId>
  <version>1.0-SNAPSHOT</version>

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

Есть мысли об этой ошибке?


person Halley    schedule 21.01.2021    source источник
comment
Вы пытались получить коллекции с помощью API Rest, чтобы проверить, нет ли чего-то странного docs.microsoft.com/en-US/rest/api/cosmos-db/list-collections?   -  person Sourcerer    schedule 07.02.2021
comment
Вы можете попробовать mongoTemplate#executeCommand - передать ему команду listCollections.   -  person prasad_    schedule 08.02.2021


Ответы (1)


Вы уверены в правильности URI вашего подключения?

Я не вижу пароль, входящий в ваш URI

Добавьте uri раздела пароля, как это

String uri= "mongodb://<username>:<password>@...
person Ramazan Demir    schedule 21.01.2021
comment
Вопрос обновлен, пароль передается. Все методы / функции, кроме getCollectionNames(), работают нормально. - person Matt Busche; 22.01.2021