【问题标题】:MongoDB via Java: CommandFailureException, code 18MongoDB 通过 Java:CommandFailureException,代码 18
【发布时间】:2014-09-17 20:41:09
【问题描述】:

从 Java 对 MongoDB 运行查询时,出现以下错误:

com.mongodb.CommandFailureException: { "serverUsed" : "AAA.BBB.CCC.DDD:27017" , "code" : 18 , "ok" : 0.0 , "errmsg" : "auth fails"}
at com.mongodb.CommandResult.getException(CommandResult.java:76)
at com.mongodb.CommandResult.throwOnError(CommandResult.java:131)
at com.mongodb.DBPort$NativeAuthenticator.authenticate(DBPort.java:652)
at com.mongodb.DBPort.authenticate(DBPort.java:364)
at com.mongodb.DBPort.checkAuth(DBPort.java:375)
at com.mongodb.DBTCPConnector.innerCall(DBTCPConnector.java:291)
at com.mongodb.DBTCPConnector.call(DBTCPConnector.java:271)
at com.mongodb.DBCollectionImpl.find(DBCollectionImpl.java:84)
at com.mongodb.DBCollectionImpl.find(DBCollectionImpl.java:66)
at com.mongodb.DBCursor._check(DBCursor.java:458)
at com.mongodb.DBCursor._hasNext(DBCursor.java:546)
at com.mongodb.DBCursor.hasNext(DBCursor.java:571)

当我在 RoboMongo 中使用相同的凭据时,我可以连接到相同的数据库。

在 Java 中,我使用以下代码连接到它:

public void init() {
    try {
        final ServerAddress serverAddress = new ServerAddress("AAA.BBB.CCC.DDD", 27017);

        final MongoCredential credential = MongoCredential.createMongoCRCredential("user", 
                "dbName", "password".toCharArray());

        mongoClient = new MongoClient(serverAddress, Arrays.asList(credential));

        db = mongoClient.getDB("dbName");
        state = getPersistenceState();
    } catch (final UnknownHostException exception) {
        LOGGER.error("", exception);
    }
}

我正在使用 MongoDB 2.4.10 和 Mongo Java 驱动程序 2.12.2。

如何修改代码才能查询和修改数据库?

【问题讨论】:

标签: java mongodb


【解决方案1】:
  1. 检查您是否能够使用 mongo shell 进行身份验证并运行查询:“mongo --authenticationDatabase dbName -u user -p”

  2. 查看 mongod 日志并查找失败的身份验证尝试 - 通常有问题

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2011-05-31
    • 1970-01-01
    • 2020-09-14
    • 1970-01-01
    • 1970-01-01
    • 2018-05-15
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多