黄潞潞
2024-06-07 482f807361c9bc0dce2db949a29c755cf858548b
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
package foundation.server;
 
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.PrintStream;
 
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
 
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
 
import foundation.handler.DataPool;
import foundation.handler.DataPoolType;
import foundation.log.LogConfig;
import foundation.route.ClientAcceptType;
import foundation.route.ControllerNavigator;
import foundation.route.Route;
import foundation.route.RouteNavigator;
import foundation.route.RouteTable;
import foundation.route.RouteType;
import foundation.route.ServerErrorNavigator;
import foundation.server.config.Configer;
import foundation.token.IOnlineUser;
import foundation.token.IUserManager;
import foundation.translator.Translator;
 
public class Dispatcher implements Filter { 
 
    public static boolean AuthorizeActive;
    private static Dispatcher instance;
    private static Logger logger;
 
    static {
        logger = LogManager.getLogger(Dispatcher.class);
    }
 
    public Dispatcher() {
        instance = this;
    }
 
    public synchronized static Dispatcher getInstance() {
        if (instance == null) {
            instance = new Dispatcher();
        }
 
        return instance;
    }
 
    public void init(FilterConfig filterConfig) throws ServletException {
        AuthorizeActive = Translator.toBoolean(Configer.getString("AuthorizeActive"), true);
    }
 
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
        HttpServletRequest request = (HttpServletRequest) req;
        HttpServletResponse response = (HttpServletResponse) res;
        
        try {
            DataPool dataPool = null;
            request.setCharacterEncoding("utf-8");
            
            //1. route and get navigator
            RouteNavigator navigator = RouteTable.matchRoute(request);
            
            //2. log
            if (LogConfig.IsActive_Dispatcher_Trace) {
                logger.debug("filter request URI:" + navigator); 
            }
            
            //3. authorize
            if (navigator.isAuthorizeSensitive() && AuthorizeActive) {
                Route route = navigator.getRoute();
                
                //3.1 user token
                dataPool = new DataPool(request);
                
                if (DataPoolType.Options == dataPool.getType()) {
                    ControllerNavigator.replyOptions(request, response);
                    return;
                }
                
                String token = dataPool.getToken();
                IOnlineUser onlineUser = IUserManager.registerUser(token);
                dataPool.setUser(onlineUser);
                
                //3.2 go to login
                if (onlineUser.isAnymous()) {
                    if (route == null) {
                        logger.info("redirct to time out for request: {}", navigator);
                        navigator.redirectToTimeOut(response, ClientAcceptType.Html);
                        return;
                    }
                    
                    RouteType routeType = route.getRouteType();
                    
                    if (RouteType.Controller == routeType) {
                        logger.info("redirct to time out for request: {}", navigator);
                        navigator.redirectToTimeOut(response, ClientAcceptType.Ajax);
                        return;
                    }
                    
                    navigator.redirectToTimeOut(response, ClientAcceptType.Html);
                    return;
                } 
            }
            
            //4. send to
            navigator.sendTo(response, dataPool);
        }
        catch (Exception e) {
            String error = printStackToString(e);
            logger.error("dispatch error:" + e.getMessage());
            logger.error(error);
            
            RouteNavigator navigator = new ServerErrorNavigator(request);
            navigator.sendTo(response, null, e);
        }
    }
    
    public void destroy() {
 
    }
 
    private String printStackToString(Exception e) {
        ByteArrayOutputStream outStream = new ByteArrayOutputStream();
        PrintStream printStream = new PrintStream(outStream);
        e.printStackTrace(printStream);
 
        return outStream.toString();
    }
 
}