OAuth2 logout

OAuth安全环境中注销用户的访问令牌

  • 定义一个@FrameworkEndpoint,以便它被FrameworkEndpointHandlerMapping取代而不是标准的RequestMappingHandlerMapping被拾取和解析.

    @FrameworkEndpoint
    public class RevokeTokenEndpoint {

    @Autowired
    @Qualifier("consumerTokenServices")
    ConsumerTokenServices consumerTokenServices;
    
    @RequestMapping(method = RequestMethod.DELETE, value = "/oauth/token")
    @ResponseBody
    public Msg<String> revokeToken(String access_token) {
        if (consumerTokenServices.revokeToken(access_token)){
            return new Msg(MessageType.MSG_TYPE_SUCCESS,null,"注销成功");
        }else{
            return new Msg(MessageType.MSG_TYPE_FAILURE,null,"注销失败");
        }
    }
    

    }

  • 上述方法从参数中获取access_token,网上还有一种方法是从request Header中获取access_token:

    public void revokeToken(HttpServletRequest request) {
        String authorization = request.getHeader("Authorization");
        if (authorization != null && authorization.contains("Bearer")){
            String tokenId = authorization.substring("Bearer".length()+1);
            tokenServices.revokeToken(tokenId);
        }
    }
    
  • 从服务器端删除cookie(针对前端页面的cookie操作)

    @Component
    public class CustomPostZuulFilter extends ZuulFilter{
    
        @Override
        public Object run() {
            final RequestContext ctx = RequestContext.getCurrentContext();
            String requestURI = ctx.getRequest().getRequestURI();
            String requestMethod = ctx.getRequest().getMethod();
            if (requestURI.contains("oauth/token") && requestMethod.equals("DELETE")) {
                Cookie cookie = new Cookie("refreshToken", "");
                cookie.setMaxAge(0);
                cookie.setPath(ctx.getRequest().getContextPath() + "/oauth/token");
                ctx.getResponse().addCookie(cookie);
            }
            return null;
        }
    
        @Override
        public boolean shouldFilter() {
            return true;
        }
    
        @Override
        public int filterOrder() {
            return 10;
        }
    
        @Override
        public String filterType() {
            return "post";
        }
    }
    
  • 从AngularJS客户端删除访问令牌,除了从令牌存储中撤销访问令牌之外,还需要从客户端删除access_token cookie。

    $scope.logout = function() {
        logout($scope.loginData);
    }
    function logout(params) {
        var req = {
        method: 'DELETE',
        url: "oauth/token"
        }
        $http(req).then(
            function(data){
                $cookies.remove("access_token");
                window.location.href="login";
            },function(){
                console.log("error");
            }
        );
    } 
    
    //单击“ 注销”链接时将调用此功能:  
    <a class="btn btn-info" href="#" ng-click="logout()">Logout</a>
    
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值