|
@@ -7,6 +7,8 @@ import com.xxl.job.core.rpc.serialize.HessianSerializer;
|
7
|
7
|
import com.xxl.job.core.util.HttpClientUtil;
|
8
|
8
|
import org.eclipse.jetty.server.Request;
|
9
|
9
|
import org.eclipse.jetty.server.handler.AbstractHandler;
|
|
10
|
+import org.slf4j.Logger;
|
|
11
|
+import org.slf4j.LoggerFactory;
|
10
|
12
|
|
11
|
13
|
import javax.servlet.ServletException;
|
12
|
14
|
import javax.servlet.http.HttpServletRequest;
|
|
@@ -19,17 +21,13 @@ import java.io.OutputStream;
|
19
|
21
|
* @author xuxueli 2015-11-19 22:32:36
|
20
|
22
|
*/
|
21
|
23
|
public class JettyServerHandler extends AbstractHandler {
|
22
|
|
-
|
|
24
|
+ private static Logger logger = LoggerFactory.getLogger(JettyServerHandler.class);
|
23
|
25
|
|
24
|
26
|
@Override
|
25
|
27
|
public void handle(String target, Request baseRequest, HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {
|
26
|
28
|
|
27
|
|
- // deserialize request
|
28
|
|
- byte[] requestBytes = HttpClientUtil.readBytes(request);
|
29
|
|
- RpcRequest rpcRequest = (RpcRequest) HessianSerializer.deserialize(requestBytes, RpcRequest.class);
|
30
|
|
-
|
31
|
29
|
// invoke
|
32
|
|
- RpcResponse rpcResponse = NetComServerFactory.invokeService(rpcRequest, null);
|
|
30
|
+ RpcResponse rpcResponse = doInvoke(request);
|
33
|
31
|
|
34
|
32
|
// serialize response
|
35
|
33
|
byte[] responseBytes = HessianSerializer.serialize(rpcResponse);
|
|
@@ -44,4 +42,27 @@ public class JettyServerHandler extends AbstractHandler {
|
44
|
42
|
|
45
|
43
|
}
|
46
|
44
|
|
|
45
|
+ private RpcResponse doInvoke(HttpServletRequest request) {
|
|
46
|
+ try {
|
|
47
|
+ // deserialize request
|
|
48
|
+ byte[] requestBytes = HttpClientUtil.readBytes(request);
|
|
49
|
+ if (requestBytes == null || requestBytes.length==0) {
|
|
50
|
+ RpcResponse rpcResponse = new RpcResponse();
|
|
51
|
+ rpcResponse.setError("RpcRequest byte[] is null");
|
|
52
|
+ return rpcResponse;
|
|
53
|
+ }
|
|
54
|
+ RpcRequest rpcRequest = (RpcRequest) HessianSerializer.deserialize(requestBytes, RpcRequest.class);
|
|
55
|
+
|
|
56
|
+ // invoke
|
|
57
|
+ RpcResponse rpcResponse = NetComServerFactory.invokeService(rpcRequest, null);
|
|
58
|
+ return rpcResponse;
|
|
59
|
+ } catch (Exception e) {
|
|
60
|
+ logger.error(e.getMessage(), e);
|
|
61
|
+
|
|
62
|
+ RpcResponse rpcResponse = new RpcResponse();
|
|
63
|
+ rpcResponse.setError("Servet-error:" + e.getMessage());
|
|
64
|
+ return rpcResponse;
|
|
65
|
+ }
|
|
66
|
+ }
|
|
67
|
+
|
47
|
68
|
}
|