use of com.generallycloud.baseio.component.LoggerSocketSEListener in project baseio by generallycloud.
the class ProtobaseApplicationContextEnricher method enrich.
@Override
public void enrich(ApplicationContext context) {
SocketChannelContext channelContext = context.getChannelContext();
context.setServiceFilter(new FutureAcceptorServiceFilter());
// FIXME 重复的
Set<String> blackIPs = context.getBlackIPs();
if (blackIPs != null && !blackIPs.isEmpty()) {
channelContext.addSessionEventListener(new BlackIPFilter(blackIPs));
}
channelContext.addSessionEventListener(new LoggerSocketSEListener());
channelContext.setProtocolFactory(new ParamedProtobaseProtocolFactory());
channelContext.setBeatFutureFactory(new ParamedProtobaseBeatFutureFactory());
}
use of com.generallycloud.baseio.component.LoggerSocketSEListener in project baseio by generallycloud.
the class SimpleTestFIxedLengthClientPush method main.
@SuppressWarnings("resource")
public static void main(String[] args) throws Exception {
IoEventHandleAdaptor eventHandleAdaptor = new IoEventHandleAdaptor() {
@Override
public void accept(SocketSession session, Future future) throws Exception {
System.out.println(">msg from server: " + future.getReadText());
}
};
SocketChannelContext context = new NioSocketChannelContext(new ServerConfiguration("localhost", 18300));
SocketChannelConnector connector = new SocketChannelConnector(context);
context.setIoEventHandleAdaptor(eventHandleAdaptor);
context.addSessionEventListener(new LoggerSocketSEListener());
context.setProtocolFactory(new FixedLengthProtocolFactory());
SocketSession session = connector.connect();
ThreadUtil.execute(new Runnable() {
@Override
public void run() {
System.out.println("************************************************");
System.out.println("提示:");
System.out.println("list(获取所有客户端id)");
System.out.println("id(获取当前客户端id)");
System.out.println("push id msg(推送消息到)");
System.out.println("broadcast msg(广播消息)");
System.out.println("exit(退出客户端)");
System.out.println("仅用于演示,msg请勿包含空格");
System.out.println("************************************************");
Scanner scanner = new Scanner(System.in);
for (; ; ) {
System.out.println(">");
String line = scanner.nextLine();
if ("exit".equals(line)) {
CloseUtil.close(session);
break;
}
FixedLengthFuture future = new FixedLengthFutureImpl(context);
future.write(line);
session.flush(future);
}
}
});
}
use of com.generallycloud.baseio.component.LoggerSocketSEListener in project baseio by generallycloud.
the class SimpleTestFIxedLengthServerPush method main.
public static void main(String[] args) throws Exception {
IoEventHandleAdaptor eventHandleAdaptor = new IoEventHandleAdaptor() {
@Override
public void accept(SocketSession session, Future future) throws Exception {
SocketSessionManager sessionManager = session.getContext().getSessionManager();
Map<Integer, SocketSession> sessions = sessionManager.getManagedSessions();
String msg = future.getReadText();
String[] arr = msg.split(" ");
String cmd = arr[0];
logger.info("msg received: {}", msg);
if ("list".equals(cmd)) {
String keys = sessions.keySet().toString();
future.write(keys);
} else if ("id".equals(cmd)) {
future.write(String.valueOf(session.getSessionId()));
} else if ("push".equals(cmd)) {
Integer id = Integer.valueOf(arr[1]);
SocketSession target = sessions.get(id);
if (target == null) {
future.write("offline id: " + id);
} else {
future.write("from [");
future.write(String.valueOf(session.getSessionId()));
future.write("] push msg>");
future.write(arr[2]);
target.flush(future);
return;
}
} else if ("broadcast".equals(cmd)) {
future.write("from [");
future.write(String.valueOf(session.getSessionId()));
future.write("] broadcast msg>");
future.write(arr[1]);
sessionManager.broadcast(future);
return;
} else {
future.write("no cmd: " + cmd);
}
session.flush(future);
}
};
SocketChannelContext context = new NioSocketChannelContext(new ServerConfiguration(18300));
SocketChannelAcceptor acceptor = new SocketChannelAcceptor(context);
context.addSessionEventListener(new LoggerSocketSEListener());
context.addSessionEventListener(new SocketSessionEventListener() {
@Override
public void sessionOpened(SocketSession session) throws Exception {
}
@Override
public void sessionClosed(SocketSession session) {
SocketSessionManager sessionManager = session.getContext().getSessionManager();
FixedLengthFuture future = new FixedLengthFutureImpl(session.getContext());
future.write("client left: " + session.getSessionId());
try {
sessionManager.broadcast(future);
} catch (IOException e) {
logger.error(e.getMessage(), e);
}
}
});
context.setIoEventHandleAdaptor(eventHandleAdaptor);
context.setProtocolFactory(new FixedLengthProtocolFactory());
acceptor.bind();
}
use of com.generallycloud.baseio.component.LoggerSocketSEListener in project baseio by generallycloud.
the class TestFIxedLengthClient method main.
public static void main(String[] args) throws Exception {
IoEventHandleAdaptor eventHandleAdaptor = new IoEventHandleAdaptor() {
@Override
public void accept(SocketSession session, Future future) throws Exception {
System.out.println();
System.out.println("____________________" + future.getReadText());
System.out.println();
}
};
SslContext sslContext = SSLUtil.initClient(true);
SocketChannelContext context = new NioSocketChannelContext(new ServerConfiguration("localhost", 18300));
SocketChannelConnector connector = new SocketChannelConnector(context);
context.setIoEventHandleAdaptor(eventHandleAdaptor);
context.addSessionEventListener(new LoggerSocketSEListener());
// context.addSessionEventListener(new SessionActiveSEListener());
context.setBeatFutureFactory(new FLBeatFutureFactory());
context.setProtocolFactory(new FixedLengthProtocolFactory());
context.setSslContext(sslContext);
SocketSession session = connector.connect();
FixedLengthFuture future = new FixedLengthFutureImpl(context);
future.write("hello server!");
session.flush(future);
ThreadUtil.sleep(100);
CloseUtil.close(connector);
DebugUtil.debug("连接已关闭。。。");
}
use of com.generallycloud.baseio.component.LoggerSocketSEListener in project baseio by generallycloud.
the class TestFIxedLengthServer method main.
public static void main(String[] args) throws Exception {
IoEventHandleAdaptor eventHandleAdaptor = new IoEventHandleAdaptor() {
@Override
public void accept(SocketSession session, Future future) throws Exception {
future.write("yes server already accept your message:");
future.write(future.getReadText());
session.flush(future);
}
};
SocketChannelContext context = new NioSocketChannelContext(new ServerConfiguration(18300));
SocketChannelAcceptor acceptor = new SocketChannelAcceptor(context);
context.addSessionEventListener(new LoggerSocketSEListener());
// context.addSessionEventListener(new SocketSessionAliveSEListener());
context.setIoEventHandleAdaptor(eventHandleAdaptor);
context.setBeatFutureFactory(new FLBeatFutureFactory());
context.setProtocolFactory(new FixedLengthProtocolFactory());
File certificate = FileUtil.readFileByCls("generallycloud.com.crt");
File privateKey = FileUtil.readFileByCls("generallycloud.com.key");
SslContext sslContext = SSLUtil.initServer(privateKey, certificate);
context.setSslContext(sslContext);
acceptor.bind();
}
Aggregations