mongodb java报授权,使用java连接Mongodb时报错code:18codeName:AuthenticationFailed时的解决方法...

连接信息:

//MongoCredential.createScramSha1Credential()三个参数分别为 用户名 数据库名称 密码MongoCredentialcredential= MongoCredential.createScramSha1Credential("root","source","123456".toCharArray());List credentials= newArrayList();credentials.add(credential);

报错信息:

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

#首先排除了【SCRAM-SHA-1】错误

经过查阅资料发现是使用了错误的授权账号

MongoDB中每个数据库之间是相互独立的,都有独立的权限,正确的做法是使用root账号在【将要操作的数据库】中创建一个【子账号】,在用这个子账号连接mongo

例如:

>use admin

switched to db admin

>db.auth("root","123456")

1

>show dbs

admin

local

testDB

>use testDB

switched to db testDB

>db.createUser(

{

user:"usertest",

pwd:"123456",

roles:[{role:"dbOwner",db:"testBD"}]

}

)

Successfully added user: {

"user" : "usertest",

"roles" : [

{

"role" : "dbOwner",

"db" : "testDB"

}

]

}

最后使用【usertest】来替换java代码中的账号【root】

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个异常信息是由于身份验证失败导致的。根据引用和引用中的异常描述,可以看出在连接MongoDB出现了身份验证失败的问题。根据引用中的配置信息,可以看到用户名和密码是正确的,但是认证的数据库配置错误,应该是将认证的数据库设置为了admin,而实际上账号密码信息在admin库里。所以需要将authentication-database的值改为正确的数据库名称(可能是mini),以便正确进行身份验证。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [{ "ok" : 0.0, "errmsg" : "Authentication failed.", "code" : 18, "codeName" : "AuthenticationFailed](https://blog.csdn.net/qq_42815754/article/details/90374403)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [‘Authentication failed.‘ on server xx.xx.xxx.x:... The full response is { “ok“ : 0.0, “errmsg](https://blog.csdn.net/qq_42025798/article/details/114417527)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [MongoDB-Springboot配置MongoDB碰到的问题](https://blog.csdn.net/qq_39595769/article/details/120043844)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值