1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20 package org.apache.mina.example.sumup;
21
22 import org.apache.mina.core.service.IoHandler;
23 import org.apache.mina.core.service.IoHandlerAdapter;
24 import org.apache.mina.core.session.IoSession;
25 import org.apache.mina.example.sumup.message.AddMessage;
26 import org.apache.mina.example.sumup.message.ResultMessage;
27 import org.slf4j.Logger;
28 import org.slf4j.LoggerFactory;
29
30
31
32
33
34
35
36 public class ClientSessionHandler extends IoHandlerAdapter {
37
38 private final Logger logger = LoggerFactory.getLogger(getClass());
39
40 private final int[] values;
41
42 private boolean finished;
43
44 public ClientSessionHandler(int[] values) {
45 this.values = values;
46 }
47
48 public boolean isFinished() {
49 return finished;
50 }
51
52 @Override
53 public void sessionOpened(IoSession session) {
54
55 for (int i = 0; i < values.length; i++) {
56 AddMessage m = new AddMessage();
57 m.setSequence(i);
58 m.setValue(values[i]);
59 session.write(m);
60 }
61 }
62
63 @Override
64 public void messageReceived(IoSession session, Object message) {
65
66
67 ResultMessage rm = (ResultMessage) message;
68 if (rm.isOk()) {
69
70
71
72
73 if (rm.getSequence() == values.length - 1) {
74
75 logger.info("The sum: " + rm.getValue());
76 session.close();
77 finished = true;
78 }
79 } else {
80
81 logger.warn("Server error, disconnecting...");
82 session.close();
83 finished = true;
84 }
85 }
86
87 @Override
88 public void exceptionCaught(IoSession session, Throwable cause) {
89 session.close();
90 }
91 }