GlobalInterceptor.java 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. package com.izouma.awesomeadmin.interceptor;
  2. import com.izouma.awesomeadmin.shiro.AppToken;
  3. import org.apache.commons.lang.StringUtils;
  4. import org.apache.shiro.SecurityUtils;
  5. import org.apache.shiro.subject.Subject;
  6. import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;
  7. import javax.servlet.http.HttpServletRequest;
  8. import javax.servlet.http.HttpServletResponse;
  9. /**
  10. * Created by xiong on 2017/6/16.
  11. */
  12. public class GlobalInterceptor extends HandlerInterceptorAdapter {
  13. @Override
  14. public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
  15. Subject subject = SecurityUtils.getSubject();
  16. if (!subject.isAuthenticated()) {
  17. String token = request.getHeader("token");
  18. if (StringUtils.isNotEmpty(token)) {
  19. AppToken appToken = new AppToken(token);
  20. try {
  21. subject.login(appToken);
  22. } catch (Exception e) {
  23. e.printStackTrace();
  24. }
  25. }
  26. }
  27. response.addHeader("Access-Control-Allow-Origin", request.getHeader("Origin"));
  28. response.addHeader("Access-Control-Allow-Methods", "*");
  29. response.addHeader("Access-Control-Max-Age", "100");
  30. response.addHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
  31. response.addHeader("Access-Control-Allow-Credentials", "true");
  32. return super.preHandle(request, response, handler);
  33. }
  34. }