关于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语句(更新中)

如何在 spring-boot 中禁用 spring-data-mongodb 自动配置

将 Spring 安全 ACL 与 spring-data-mongodb 一起使用