Чтобы выполнить базовую проверку подлинности в RESTlet 2.0 (я предполагаю, что вы используете 2.0, так как вы указываете ServerResource
), вам необходимо использовать ChallengeAuthenticator
. Если это настроено с помощью optional = true
, тогда аутентификация будет запрашиваться только при вызове ChallengeAuthenticator.challenge()
.
Вы можете создать приложение с authenticate()
способом, и называют это всякий раз, когда вам нужно получить доступ к ресурсу, чтобы быть обеспечено:
Применение:
package example;
import org.restlet.*;
import org.restlet.data.ChallengeScheme;
import org.restlet.routing.Router;
import org.restlet.security.*;
public class ExampleApp extends Application {
private ChallengeAuthenticator authenticatior;
private ChallengeAuthenticator createAuthenticator() {
Context context = getContext();
boolean optional = true;
ChallengeScheme challengeScheme = ChallengeScheme.HTTP_BASIC;
String realm = "Example site";
// MapVerifier isn't very secure; see docs for alternatives
MapVerifier verifier = new MapVerifier();
verifier.getLocalSecrets().put("user", "password".toCharArray());
ChallengeAuthenticator auth = new ChallengeAuthenticator(context, optional, challengeScheme, realm, verifier) {
@Override
protected boolean authenticate(Request request, Response response) {
if (request.getChallengeResponse() == null) {
return false;
} else {
return super.authenticate(request, response);
}
}
};
return auth;
}
@Override
public Restlet createInboundRoot() {
this.authenticatior = createAuthenticator();
Router router = new Router();
router.attach("/user", UserResource.class);
authenticatior.setNext(router);
return authenticatior;
}
public boolean authenticate(Request request, Response response) {
if (!request.getClientInfo().isAuthenticated()) {
authenticatior.challenge(response, false);
return false;
}
return true;
}
}
Ресурс:
package example;
import org.restlet.data.MediaType;
import org.restlet.representation.EmptyRepresentation;
import org.restlet.representation.Representation;
import org.restlet.representation.StringRepresentation;
import org.restlet.resource.ServerResource;
public class UserResource extends ServerResource {
@Override
public Representation get() {
ExampleApp app = (ExampleApp) getApplication();
if (!app.authenticate(getRequest(), getResponse())) {
// Not authenticated
return new EmptyRepresentation();
}
// Generate list of users
// ...
}
@Override
public Representation post(Representation entity) {
// Handle post
// ...
}
}
Прежде всего спасибо за ваш ответ, это выглядит многообещающим. Тем не менее, у меня есть некоторые проблемы с тем, чтобы ваш код работал. Например, для ClientInfo нет метода 'getSubject()' (я использую 2.0m7). Кроме того, я не уверен, правильный ли метод 'authenticate()'? –
Я использовал более ранний снимок; Я обновил примеры для работы с 2.0m7. – Sam
Спасибо, опять же, теперь компилируется код и POST. К сожалению, GET никогда не бывает. Независимо от того, предоставляю ли я никаких, неправильных или правильных учетных данных BASIC, я всегда получаю 401. –