Mongodb 验证MongoCredential和未分类Mongo Db异常的异常
我在运行应用程序时收到此连接引发的错误套接字异常。Mongodb 验证MongoCredential和未分类Mongo Db异常的异常,mongodb,spring-boot,Mongodb,Spring Boot,我在运行应用程序时收到此连接引发的错误套接字异常。 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.da
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
INFO 5231---[nio-8087-exec-1]org.mongodb.driver.connection:关闭连接[connectionId{localValue:2}]到192.168.0.2:27017,因为此连接引发了套接字异常**
org.springframework.data.mongodb.uncategorizedmongodbeexception:验证MongoCredential{mechanism=SCRAM-SHA-1,userName='admin',source='campbell',password=,mechanismProperties={}的异常;嵌套异常是com.mongodb.MongoSecurityException:验证MongoCredential{mechanism=SCRAM-SHA-1,userName='admin',source='campbell',password=,mechanismProperties={}的异常
位于org.springframework.data.mongodb.core.MongoExceptionTranslator.TranslateExceptionIfBlability(MongoExceptionTranslator.java:138)
位于org.springframework.data.mongodb.core.MongoTemplate.potentiallyConvertRuntimeException(MongoTemplate.java:2756)
位于org.springframework.data.mongodb.core.MongoTemplate.executeFindMultiInternal(MongoTemplate.java:2666)
位于org.springframework.data.mongodb.core.MongoTemplate.doFind(MongoTemplate.java:2409)
位于org.springframework.data.mongodb.core.ExecutableFindOperationSupport$ExecutableFindSupport.doFind(ExecutableFindOperationSupport.java:214)
位于org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
位于org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)
位于org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
位于org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:490)
位于org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
位于org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
位于org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
位于org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
位于org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:408)
位于org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
位于org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:791)
位于org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1417)
位于org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
位于java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
位于java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
位于org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
原因:com.mongodb.MongoSecurityException:验证MongoCredential{mechanism=SCRAM-SHA-1,userName='admin',source='campbell',password=,mechanismProperties={}的异常
原因:com.mongodb.MongoCommandException:命令失败,错误为18(AuthenticationFailed):“身份验证失败”。在服务器192.168.0.2:27017上。完整响应为{“ok”:0.0,“errmsg”:“身份验证失败”,“code”:18,“codeName”:“AuthenticationFailed”}
**我在应用程序属性中声明了属性-**
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异常
请帮帮我 根据,设置spring.data.mongodb.authentication database=admin
可能会解决您的问题
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" } ]
}
)
MongoDB中的默认数据库是test
,因此,您可能正在尝试对test
数据库进行身份验证。切换到admin
数据库(创建用户的常用位置)可能会解决您的问题。您可以尝试以下方法:
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" } ]
}
)
spring.data.mongodb.uri=mongodb://user:passwod@localhost/test?authSource=admin
您是否指定了
身份验证数据库
?很可能您正在针对不同的数据库验证用户所处的位置。在应用程序属性中添加此行-spring.data.mongodb.authentication-database=admin后签出。现在它工作正常。非常感谢。太好了!我添加了一个答案来帮助未来的SO用户。如果你觉得这对你有帮助,请接受这一正确答案。谢谢。你让我度过了我的一天这对我来说不起作用,但我做的是在连接字符串中添加以下选项:authSource=
你保存了我的一天。太好了。。!我的情况正好相反。删除它之后,它工作了。@NachoMezzadra这意味着您的用户不是管理数据库的一部分,而是另一个数据库的一部分。