Dies ist eine konzeptionelle Frage.
Ich habe eine Client- (mobile) Anwendung, die eine Anmeldeaktion für einen RESTful-Webdienst unterstützen muss. Da der Webdienst RESTful ist, bedeutet dies, dass der Client einen Benutzernamen / ein Kennwort vom Benutzer akzeptiert, diesen Benutzernamen / dieses Kennwort mit dem Dienst überprüft und dann nur daran denkt, diesen Benutzernamen / dieses Kennwort bei allen nachfolgenden Anforderungen zu senden.
Alle anderen Antworten in diesem Webdienst werden in einem JSON-Format bereitgestellt.
Die Frage ist, wenn ich den Webdienst einfach abfrage, um herauszufinden, ob ein bestimmter Benutzername / ein bestimmtes Kennwort gültig ist, ob der Webdienst immer mit JSON-Daten antwortet, die mir mitteilen, ob er erfolgreich oder nicht erfolgreich ist, oder ob er HTTP 200 mit guten Anmeldeinformationen und HTTP zurückgibt 401 bei schlechten Anmeldeinformationen.
Der Grund, den ich frage, ist, dass einige andere RESTful-Dienste 401 für fehlerhafte Anmeldeinformationen verwenden, selbst wenn Sie nur fragen, ob die Anmeldeinformationen gültig sind. Nach meinem Verständnis von 401-Antworten handelt es sich jedoch um eine Ressource, auf die Sie ohne gültige Anmeldeinformationen keinen Zugriff haben sollten. Die Anmelderessource SOLLTE jedoch für jedermann zugänglich sein, da der gesamte Zweck der Anmelderessource darin besteht, Ihnen mitzuteilen, ob Ihre Anmeldeinformationen gültig sind.
Anders ausgedrückt, es scheint mir, dass eine Anfrage wie:
myservice.com/this/is/a/user/action
sollte 401 zurückgeben, wenn falsche Anmeldeinformationen angegeben werden. Aber eine Anfrage wie:
myservice.com/are/these/credentials/valid
sollte niemals 401 zurückgeben, da diese bestimmte URL (Anfrage) mit oder ohne gültige Anmeldeinformationen autorisiert ist.
Ich würde gerne einige berechtigte Meinungen dazu hören. Was ist die Standardmethode, um damit umzugehen, und ist die Standardmethode, um damit umzugehen, logisch angemessen?