package com.pannk.mms.common.oauth2; import com.alibaba.fastjson.JSON; import com.pannk.mms.common.base.Result; import org.apache.shiro.authc.AuthenticationToken; import org.apache.shiro.web.filter.authc.AuthenticatingFilter; import org.junit.platform.commons.util.StringUtils; import org.springframework.http.HttpStatus; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * Created by wolf on 20-11-6. */ public class OAuth2Filter extends AuthenticatingFilter { @Override protected AuthenticationToken createToken(ServletRequest servletRequest, ServletResponse servletResponse) throws Exception { String token = getToken(servletRequest); if (StringUtils.isBlank(token)) { return null; } return new OAuth2Token(token); } @Override protected boolean onAccessDenied(ServletRequest servletRequest, ServletResponse servletResponse) throws Exception { String token = getToken(servletRequest); if (StringUtils.isBlank(token)) { HttpServletResponse httpServletResponse = (HttpServletResponse) servletResponse; httpServletResponse.setHeader("Access-Control-Allow-Credentials", "true"); httpServletResponse.setHeader("Access-Control-Allow-Origin", ((HttpServletRequest) servletRequest).getHeader("Origin")); String responJson = JSON.toJSONString(Result.error(HttpStatus.FORBIDDEN.value(), HttpStatus.FORBIDDEN.getReasonPhrase())); httpServletResponse.getWriter().print(responJson); return false; } return executeLogin(servletRequest,servletResponse); } private String getToken(ServletRequest request) { return ((HttpServletRequest) request).getHeader("X-Token"); } }