【问题标题】:Exception authenticating MongoCredential and Uncategorized Mongo Db Exception验证 MongoCredential 的异常和未分类的 Mongo Db 异常
【发布时间】:2019-08-03 17:55:12
【问题描述】:

我在运行我的应用程序时收到此连接引发的错误套接字异常。

INFO 5231 --- [nio-8087-exec-1] org.mongodb.driver.connection: Closed connection [connectionId{localValue:2}] to 192.168.0.2:27017 because there was a socket exception raised by this connection.**

    org.springframework.data.mongodb.UncategorizedMongoDbException: Exception authenticating MongoCredential{mechanism=SCRAM-SHA-1, userName='admin', source='campbell', password=<hidden>, mechanismProperties={}}; nested exception is com.mongodb.MongoSecurityException: Exception authenticating MongoCredential{mechanism=SCRAM-SHA-1, userName='admin', source='campbell', password=<hidden>, mechanismProperties={}}
        at org.springframework.data.mongodb.core.MongoExceptionTranslator.translateExceptionIfPossible(MongoExceptionTranslator.java:138)
        at org.springframework.data.mongodb.core.MongoTemplate.potentiallyConvertRuntimeException(MongoTemplate.java:2756)
        at org.springframework.data.mongodb.core.MongoTemplate.executeFindMultiInternal(MongoTemplate.java:2666)
        at org.springframework.data.mongodb.core.MongoTemplate.doFind(MongoTemplate.java:2409)
        at org.springframework.data.mongodb.core.ExecutableFindOperationSupport$ExecutableFindSupport.doFind(ExecutableFindOperationSupport.java:214)

        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)
        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
        at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:490)
        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
        at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:408)
        at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
        at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:791)
        at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1417)
        at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
        at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)

    Caused by: com.mongodb.MongoSecurityException: Exception authenticating MongoCredential{mechanism=SCRAM-SHA-1, userName='admin', source='campbell', password=<hidden>, mechanismProperties={}}

    Caused by: com.mongodb.MongoCommandException: Command failed with error 18 (AuthenticationFailed): 'Authentication failed.' on server 192.168.0.2:27017. The full response is { "ok" : 0.0, "errmsg" : "Authentication failed.", "code" : 18, "codeName" : "AuthenticationFailed" }

**I have declared properties in application properties-**
spring.data.mongodb.database=dbname
spring.data.mongodb.username=admin
spring.data.mongodb.password=*******
spring.data.mongodb.port=27017
spring.data.mongodb.host=192.168.0.2

登录凭据正确我仍然收到此错误。 验证 MongoCredential 的异常我也得到了未分类的 Mongo Db 异常

请帮帮我!

【问题讨论】:

  • 您是否指定了authenticationDatabase?您可能正在针对用户所在的不同数据库进行身份验证。查看stackoverflow.com/questions/46934427/…
  • 在应用程序属性中添加这一行后 - spring.data.mongodb.authentication-database = admin。现在它工作正常。谢谢!
  • 太好了!我添加了一个答案来帮助未来的 SO 用户。如果您觉得这对您有所帮助,请接受此作为正确答案。谢谢。

标签: mongodb spring-boot


【解决方案1】:

根据#46934427,设置spring.data.mongodb.authentication-database=admin 可能会解决您的问题。

MongoDB 中的默认数据库是test,因此,您很可能正尝试针对test 数据库进行身份验证。切换到 admin 数据库(创建用户的常用位置)可能会解决您的问题。

【讨论】:

  • 你成就了我的一天
  • 这对我不起作用,但所做的是将以下选项添加到连接字符串:authSource=&lt;auth_db_name&gt;
  • 你拯救了我的一天。甜..!
  • 在我的情况下正好相反。删除后,它起作用了。
  • @NachoMezzadra 这意味着您的用户不是管理员数据库的一部分,而是另一个数据库的一部分。
【解决方案2】:

你可以试试这个:

spring.data.mongodb.uri=mongodb://user:passwod@localhost/test?authSource=admin

【讨论】:

  • 它为我解决了!
【解决方案3】:

将这些配置放入您的应用程序属性文件中:

spring.data.mongodb.host= YOUR_HOST like 192.168.x.x
spring.data.mongodb.port=27017
spring.data.mongodb.authentication-database=admin
spring.data.mongodb.username=admin
spring.data.mongodb.password=PASSWORD
spring.data.mongodb.database=DB_NAME

【讨论】:

    【解决方案4】:
    Add user admin into your database. 
    Open installed folder and open the mongo.exe file and run below command : 
    use admin
    db.createUser(
    {
    user: "admin",
    pwd: "admin",
    roles: [ { role: "userAdminAnyDatabase", db: "admin" },
    { role: "dbAdminAnyDatabase", db: "admin" },
    { role: "readWriteAnyDatabase", db: "admin" } ]
    }
    )
    

    【讨论】:

      猜你喜欢
      • 2022-01-09
      • 1970-01-01
      • 1970-01-01
      • 2014-01-18
      • 1970-01-01
      • 2015-04-16
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多