7d99859145045916a37b6a6bb62d2acced2e7ccf
[institute/sw-backend.git] /
1 package com.supwisdom.institute.backend.common.core.transmit.filter;
2
3 import java.io.IOException;
4 import java.net.URLDecoder;
5
6 import javax.servlet.Filter;
7 import javax.servlet.FilterChain;
8 import javax.servlet.FilterConfig;
9 import javax.servlet.ServletException;
10 import javax.servlet.ServletRequest;
11 import javax.servlet.ServletResponse;
12 import javax.servlet.http.HttpServletRequest;
13
14 import org.apache.commons.lang3.StringUtils;
15
16 import com.alibaba.fastjson.JSON;
17 import com.supwisdom.institute.backend.common.core.transmit.user.User;
18 import com.supwisdom.institute.backend.common.core.transmit.user.UserContext;
19
20 import lombok.extern.slf4j.Slf4j;
21
22 @Slf4j
23 public class SimpleUserTransmitFilter implements Filter {
24
25   @Override
26   public void init(FilterConfig filterConfig) throws ServletException {
27     
28   }
29
30   @Override
31   public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
32     HttpServletRequest request = (HttpServletRequest) servletRequest;
33     
34     String headerValue = request.getHeader(UserContext.KEY_USER_IN_HTTP_HEADER);
35     log.debug("Header {} is: {}", UserContext.KEY_USER_IN_HTTP_HEADER, headerValue);
36     if (StringUtils.isNotBlank(headerValue)) {
37       try {
38         String jsonUser = URLDecoder.decode(headerValue,"UTF-8");
39         log.debug("jsonUser is: {}", jsonUser);
40         
41         User user = JSON.parseObject(jsonUser, User.class);
42         log.debug("User is: {}", user);
43         
44         UserContext.setUser(user);
45       } catch (Exception e) {
46         log.warn("User get error", e);
47       }
48     }
49     
50     filterChain.doFilter(servletRequest, servletResponse);
51   }
52
53   @Override
54   public void destroy() {
55     
56   }
57
58 }