关于spring-data-mongodb用户名密码登录报错问题:Failed to authenticate to database
Posted hkds
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于spring-data-mongodb用户名密码登录报错问题:Failed to authenticate to database相关的知识,希望对你有一定的参考价值。
一.问题
1.spring-data-mongodb用户名密码登录报错问题:Failed to authenticate to database
org.springframework.data.mongodb.CannotGetMongoDbConnectionException: Failed to authenticate to database [ashop], username = [ashop], password = [g***********4]
org.springframework.data.mongodb.core.ReflectiveDbInvoker.authenticate(ReflectiveDbInvoker.java:83)
org.springframework.data.mongodb.core.MongoDbUtils.doGetDB(MongoDbUtils.java:127)
org.springframework.data.mongodb.core.MongoDbUtils.getDB(MongoDbUtils.java:94)
org.springframework.data.mongodb.core.SimpleMongoDbFactory.getDb(SimpleMongoDbFactory.java:203)
org.springframework.data.mongodb.core.SimpleMongoDbFactory.getDb(SimpleMongoDbFactory.java:191)
org.springframework.data.mongodb.core.MongoTemplate.getDb(MongoTemplate.java:1606)
org.springframework.data.mongodb.core.MongoTemplate.executeFindOneInternal(MongoTemplate.java:1839)
org.springframework.data.mongodb.core.MongoTemplate.doFindOne(MongoTemplate.java:1656)
org.springframework.data.mongodb.core.MongoTemplate.findOne(MongoTemplate.java:564)
org.springframework.data.mongodb.core.MongoTemplate.findOne(MongoTemplate.java:559)
com.oneday.ashop.core.base.mongo.BaseMongoDaoSupport.findOne(BaseMongoDaoSupport.java:81)
com.oneday.ashop.webgate.user.UserDao.findUser(UserDao.java:44)
com.oneday.ashop.webgate.user.UserService.login(UserService.java:88)
com.oneday.ashop.webgate.user.UserControl.login(UserControl.java:57)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
java.lang.reflect.Method.invoke(Unknown Source)
org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:221)
org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:137)
org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:110)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:776)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:705)
org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85)
org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:959)
org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:893)
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:966)
org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:868)
javax.servlet.http.HttpServlet.service(HttpServlet.java:648)
org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:842)
javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:85)
二.解决方法
2.1.首先是mongodb数据库设置密码
登录mong shell,
>use admin
>db.system.users.remove({})
>db.system.version.remove({})
>db.system.version.insert({"_id","authSchema","currentVersion":3})
>use testdb
>db.createUser({user:"abc",pwd:"123456"},roles["readWrite","dbAdmin"])
mongo服务以登录验证权限方式启动命令:
切换到mongod安装路径下,执行:./mongod --dbpath=/home/db/data -auth --logpath=/home/db/logs/mongodb.log
2.2项目中spring配置
(1)添加相应jar包:
Maven项目的pom.xml添加spring-data-mongodb的jar包,如下
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-mongodb</artifactId>
<version>1.10.3.RELEASE</version>
</dependency>
由于spring-data-mongodb默认依赖的mongo-java-drive驱动包是2.*.*版本的,所以我们手动添加3.*版本的mongodb驱动包,如下
<dependency>
<groupId>org.mongodb</groupId>
<artifactId>mongo-java-driver</artifactId>
<version>3.2.2</version>
</dependency>
(2)配置文件
<mongo:mongo-client id="mongo" host="${mongo.host}"
port="${mongo.port}" credentials="${mongo.username}:${mongo.password}@${mongo.dbname}">
<mongo:client-options connections-per-host="${mongo.connectionsPerHost}"
write-concern="SAFE"
threads-allowed-to-block-for-connection-multiplier="${mongo.threadsAllowedToBlockForConnectionMultiplier}"
connect-timeout="${mongo.connectTimeout}" max-wait-time="${mongo.maxWaitTime}"
socket-keep-alive="${mongo.socketKeepAlive}" socket-timeout="${mongo.socketTimeout}" />
</mongo:mongo-client>
<!-- 设置使用的数据库 名 -->
<mongo:db-factory id="mongoDbFactory" dbname="${mongo.dbname}"
mongo-ref="mongo" />
<!-- mongodb的模板 -->
<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
<constructor-arg name="mongoDbFactory" ref="mongoDbFactory" />
其中,mongodb3.×的java驱动包,属性配置是<mongo:client-options>而不在是<mongo:options>.
以上是关于关于spring-data-mongodb用户名密码登录报错问题:Failed to authenticate to database的主要内容,如果未能解决你的问题,请参考以下文章
mongodb分组函数的使用(spring-data-mongodb)
Mongodb系列- 使用spring-data-mongodb实现分页查询
spring-data-mongodb 在一个 Mongo 实例中连接多个数据库
spring-data-mongodb 使用原生aggregate语句(更新中)