21

我正在尝试在 jersey 1.11 过滤器中为 rest 调用实现用户身份验证。

这是我尝试过的

package com.ilrn.session.webservices.rest.filter;

import com.ilrn.entity.User;;
import com.sun.jersey.spi.container.ContainerRequest;
import com.sun.jersey.spi.container.ContainerRequestFilter;

public class CustomFilter implements ContainerRequestFilter{

    @Override
    public ContainerRequest filter(ContainerRequest request) {
        User user = Helper.getCurrentUser();
        if(user == null){
            //Need to add custom response and abort request
        }
        return request;
    }

}

有谁知道任何方法或东西来实现同样的目标?

4

1 回答 1

45

如果出现错误,如果要发送自定义响应,则需要抛出 WebApplicationException。创建一个 Response 对象并使用以下异常构造函数将其发回:

WebApplicationException(Response response) 
          Construct a new instance using the supplied response

尝试这个:

@Override
public ContainerRequest filter(ContainerRequest request) {
    User user = Helper.getCurrentUser();
    if(user == null){
        ResponseBuilder builder = null;
        String response = "Custom message";
        builder = Response.status(Response.Status.UNAUTHORIZED).entity(response);
        throw new WebApplicationException(builder.build());

    }
    return request;
}
于 2013-06-17T08:58:08.670 回答