Sto realizzando il progetto MongoDB basato sul driver .NET 2.0 che implica l'autenticazione su MongoDB. C'è un codice di esempio per quello che sto facendo:Catch MongoAuthenticationException in Mongo .NET 2.0 Driver
public static bool createConneciton(string login, SecureString pass, string authDB) {
var settings = new MongoClientSettings {
Credentials = new[] {
MongoCredential.CreateCredential(authDB, login, pass)
},
Server = new MongoServerAddress("my.mongodb.server", 27017)
};
mongoClient = new MongoClient(settings);
return true;
}
if (Mongo.createConneciton(textBoxUsername.Text, pass, textBoxAuthDatabase.Text))
Task<BsonDocument> results = Mongo.getNodeStats();
public static async Task<BsonDocument> getNodeStats() {
try {
var db = Mongo.mongoClient.GetDatabase("admin");
var command = new BsonDocument {
{"serverStatus",1}
};
BsonDocument result = await db.RunCommandAsync<BsonDocument>(command).ConfigureAwait(false);
return result;
}
catch (Exception ex)
{
Logging.Log(ex);
return null;
}
}
Il problema principale che ho riscontrato finora è l'elaborazione delle credenziali dell'utente. Poiché tutte le operazioni sono pigre e la connessione si apre solo all'esecuzione nel metodo getNodeStats(). Quindi, se l'utente digita le credenziali errate, aspetterà per 30 secondi perché invece di MongoDB.AuthenticationException o anche del metodo MongoDB.ConnectionException andrà a eccezione dell'eccezione System.Timeout. Se si guarda il testo dell'eccezione è abbastanza ovvio che entrambi sono aumentati ma non catturati.
"MongoDB.Driver.MongoConnectionException: An exception occurred while opening a connection to the server. ---> MongoDB.Driver.MongoAuthenticationException: Unable to authenticate using sasl protocol mechanism SCRAM-SHA-1
Il mio primo pensiero è stato quello di costringere connessione aperta per controllare le credenziali appena utente li digitato e ha colpito il pulsante collegare piuttosto che in attesa di un comando da eseguire, ma a quanto pare classe MongoClient non ha .Open() metodo più. Quindi, se non sembra possibile, vorrei almeno catturare AuthenticationException senza dover attendere il timeout, ma senza idee dove dovrei provare a prenderlo.
Per curiosità, hai trovato una risposta a questo problema? – Mantisen