泽西,雄猫和安全注释

时间:2010-02-18 18:56:38

标签: tomcat annotations jersey

我需要在Tomcat 6.0.24容器中保护一个简单的Jersey RESTful API。我想使用tomcat-users.xml文件继续使用基本身份验证进行身份验证来定义用户和角色(现在就像我说的那样小)。

现在,对于授权,我希望能够使用JSR 250注释,例如@RolesAllowed@PermitAll@DenyAll等。

我不能为我的生活弄清楚如何把这一切都连在一起。

我真的不想去Spring Security路线,因为我现在需要一些非常简单的东西。

有人能指出我正确的方向吗?

1 个答案:

答案 0 :(得分:1)

您可以首先使用涵盖身份验证和权限管理的过滤器。 通过实现ResourceFilter和ContainerRequestFilter,您可以获得httpRequest,然后会话将您的应用程序/请求重定向到相关方法。

对于权限管理,您可以实现SecurityContext过滤器。你必须首先检查isUserInRole,让请求进入方法。

以下是SecurityContext实现的示例:

 public class SecurityContextImpl implements SecurityContext {

    private final SessionUser user;

    public SecurityContextImpl(SessionUser user) {
        this.user = user;
    }

    public Principal getUserPrincipal() {
        return user;
    }

    public boolean isUserInRole(String role) {

        if(user == null) {
            throw new AuthenticationException();
        }
        if(ObjectUtil.isNull(user.getPrivileges())){
            throw new AuthenticationException();
        }
        if(!user.getPrivileges().contains(role)) {
            throw new InvalidAuthorizationHeaderException();
        }
        return user.getPrivileges().contains(role);
    }

    public boolean isSecure() {
        return false;
    }

    public String getAuthenticationScheme() {
        return SecurityContext.BASIC_AUTH;
    }
}

这是基本的SecurityContextFilter实现:

    public class SecurityContextFilter implements ResourceFilter, ContainerRequestFilter {

    private static final Logger LOG = LoggerFactory.getLogger(SecurityContextFilter.class);

    protected static final String HEADER_AUTHORIZATION = "Authorization";

    protected static final String HEADER_DATE = "x-java-rest-date";

    protected static final String HEADER_NONCE = "nonce";


    private HttpServletRequest httpRequest;




    public SecurityContextFilter() {


    }


    public ContainerRequest filter(ContainerRequest request) {

        SessionUser sessionUser = (SessionUser) httpRequest
                .getSession()
                .getAttribute("sessionUser");

        request.setSecurityContext(new SecurityContextImpl(sessionUser));

        return request;
    }


    public ContainerRequestFilter getRequestFilter() {
        return this;
    }

    public ContainerResponseFilter getResponseFilter() {
        return null;
    }

    public HttpServletRequest getHttpRequest() {
        return httpRequest;
    }

    public void setHttpRequest(HttpServletRequest httpRequest) {
        this.httpRequest = httpRequest;
    }


}

不要忘记将过滤器作为init-param放在web.xml中,

然后,您可以使用您的角色权限身份验证逻辑来​​处理请求。