jersey中@RolesAllowed的使用

在jersey中使用@RolesAllowed来控制指定的角色才可以访问,一般用于方法上面。

假定只有admin的用户才可以访问。

下面是使用步骤:

第一步:定义一个类MySecurityContext实现SecurityContext

import javax.ws.rs.core.SecurityContext;
import java.security.Principal;
import java.util.List;

/**
 * @author xiaojun
 * @version 2018/12/20
 */
public class MySecurityContext implements SecurityContext {

    List<String> roleList; //定义一个集合存储所有的角色列表

    MySecurityContext(List<String> roleList) {
        this.roleList = roleList;
    }
    @Override
    public Principal getUserPrincipal() {
        return null;
    }

    @Override
    public boolean isUserInRole(String role) {
        return roleList.contains(role);   //这是关键点
    }

    @Override
    public boolean isSecure() {
        return false;
    }

    @Override
    public String getAuthenticationScheme() {
        return null;
    }
}

第二步:定义一个过滤器

import javax.ws.rs.container.ContainerRequestContext;
import javax.ws.rs.container.ContainerRequestFilter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

/**
 * @author xiaojun
 * @version 2018/12/20
 */
public class MyFilter implements ContainerRequestFilter {
    @Override
    public void filter(ContainerRequestContext requestContext) throws IOException {

        List<String> roleList = new ArrayList();
        //TODO 省略如何获得角色列表
        requestContext.setSecurityContext(new MySecurityContext(roleList));
    }
}

第三步:注册

new ResourceConfig().register(RolesAllowedDynamicFeature.class).register(MyFilter.class)

:::tip 提示
在使用@RolesAllowed的情况下,一般也会使用另一个验证用户登录的过滤器,在注册验证用户登录的过滤器时要设置其优先级,确保其在验证角色过滤器的前面执行。如:new ResourceConfig().register(MyFilter.class).register(TokenFilter.class,1);数字越小,过滤器优先级越高。
:::


   转载规则


《jersey中@RolesAllowed的使用》 孤独如梦 采用 知识共享署名 4.0 国际许可协议 进行许可。
 上一篇
jersey实现动态绑定 jersey实现动态绑定
业务场景对外提供接口服务时,需要基于token进行拦截。需要拦截指定的请求,根据token判断用户信息有效性。此文不提供token实现方法。 传统实现传统作法是直接使用一个拦截器,然后拦截所有的请求,通过配置白名单的方式,如果不是白名单的请
2019-06-06
下一篇 
zookeeper 日志清理 zookeeper 日志清理
日志路径zookeeper的配置文件zoo.cfg中,有一个dataDir的配置项,这个就是配置zookeeper快照和事务日志的存储路径。 快照日志和事物日志可以分开配置,如下配置: dataDir=/data/hadoop/zookee
2019-06-06
  目录