AbstractVirtualBoxClientHandler.java 3.59 KB
package com.example.mina.client.base;


import com.example.mina.client.entity.AbstractClientMessage;
import com.example.mina.client.entity.Command;
import com.example.mina.server.base.AbstractHardwareDataBuffer;
import com.example.mina.server.util.LogUtils;
import lombok.Data;
import org.apache.mina.core.service.IoHandlerAdapter;
import org.apache.mina.core.session.IdleStatus;
import org.apache.mina.core.session.IoSession;

import java.io.UnsupportedEncodingException;
import java.nio.charset.StandardCharsets;

@Data
public abstract class AbstractVirtualBoxClientHandler extends IoHandlerAdapter {

    protected AbstractClientMessage clientMessage;

    protected AbstractHardwareDataBuffer hardwareDataBuffer;

    public AbstractVirtualBoxClientHandler(AbstractClientMessage clientMessage,
                                           AbstractHardwareDataBuffer abstractHardwareDataBuffer) {
        this.clientMessage = clientMessage;
        this.hardwareDataBuffer = abstractHardwareDataBuffer;
    }

    @Override
    public void exceptionCaught(IoSession session, Throwable throwable) {
        System.out.println("客户端exceptionCaught被调用!");
        throwable.printStackTrace();
    }

    @Override
    public void messageReceived(IoSession session, Object message) {
        handleCommandResponse(clientMessage.getCommands().get(1).getBytes(), (byte[]) message, ((byte[]) message).length);
        System.out.println("客户端messageReceived被调用!");
        System.out.println("client端接收信息:" + new String((byte[])message, StandardCharsets.UTF_8));
        LogUtils.println("client端接收信息hex:",(byte[])message);
    }

    @Override
    public void messageSent(IoSession session, Object message) {
        System.out.println("客户端messageSent被调用!");
        System.out.println("client端发送信息:" + new String((byte[])message, StandardCharsets.UTF_8));
        LogUtils.println("client端发送信息hex:",(byte[])message);
    }

    @Override
    public void inputClosed(IoSession session) {
        System.out.println("客户端inputClosed被调用!");
        System.out.println("client端:" + session.getId() + " 关闭输入");
    }

    @Override
    public void sessionClosed(IoSession session) {
        System.out.println("客户端sessionClosed被调用!");
        System.out.println("client端与:" + session.getRemoteAddress().toString() + " 关闭连接");
        System.exit(0);
    }

    @Override
    public void sessionCreated(IoSession session) {
        System.out.println("客户端sessionCreated被调用!");
        System.out.println("client端与:" + session.getRemoteAddress().toString() + " 建立连接");
    }

    @Override
    public void sessionIdle(IoSession session, IdleStatus status) {
        System.out.println("客户端sessionIdle被调用!");
        System.out.println("client端闲置连接:会话 " + session.getId() + " 被触发 " + session.getIdleCount(status) + " 次");
    }

    @Override
    public void sessionOpened(IoSession session) {
        //        for (int i = 0; i < clientMessage.getCommands().size(); i++) {
//            handleOneCommand(i, session);
//        }
//        handleOneCommand(1, session);
        System.out.println("客户端sessionOpened被调用!");
        System.out.println("client端打开连接");
    }

    protected void handleOneCommand(int i, IoSession session) {

        Command command = clientMessage.getCommands().get(i);

        session.write(command.getBytes());
    }

    protected abstract boolean handleCommandResponse(byte[] cmd, byte[] response, int responseLen);

}