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

#mongodb #spring-boot #azure-cosmosdb #spring-mongodb

#mongodb #пружинная загрузка #azure-cosmosdb #spring-mongodb

Вопрос:

Я пытаюсь получить список коллекций в базе данных. Мое приложение использует 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>
 

Есть какие-либо мысли по поводу этой ошибки?

Комментарии:

1. Вы пытались получить коллекции с помощью API Rest, чтобы проверить, есть ли что-то странное docs.microsoft.com/en-US/rest/api/cosmos-db/list-collections ?

2. Вы можете попробовать mongoTemplate#executeCommand передать ему команду listCollections .

Ответ №1:

Вы уверены, что ваш uri соединения корректен?

я не могу видеть часть пароля в вашем uri

Добавьте uri раздела паролей следующим образом

 String uri= "mongodb://<username>:<password>@...
 

Комментарии:

1. Вопрос обновлен, пароль передается. Все методы / функции, отличные от getCollectionNames() работы нормально.