java mina 服务端_Mina客户端和服务端代码编写

1、客户端

package com.boonya.protocol;

import java.net.InetSocketAddress;

import java.nio.charset.Charset;

import org.apache.log4j.Logger;

import org.apache.mina.core.future.ConnectFuture;

import org.apache.mina.core.service.IoConnector;

import org.apache.mina.core.session.IoSession;

import org.apache.mina.filter.codec.ProtocolCodecFilter;

import org.apache.mina.filter.codec.textline.LineDelimiter;

import org.apache.mina.filter.codec.textline.TextLineCodecFactory;

import org.apache.mina.transport.socket.nio.NioSocketConnector;

import com.boonya.protocol.handler.request.ClientMessageHandler;

public class MyClient {

private static Logger logger = Logger.getLogger(MyClient.class);

private static String HOST = "127.0.0.1";

private static int PORT = 8900;

public static void main(String[] args) {

// 创建一个非组设的客户端客户端

IoConnector connector = new NioSocketConnector();

// 设置链接超时时间

connector.setConnectTimeoutMillis(30000);

// 添加过滤器

connector.getFilterChain().addLast( // 添加消息过滤器

"codec",

// Mina自带的根据文本换行符编解码的TextLineCodec过滤器 看到\r\n就认为一个完整的消息结束了

new ProtocolCodecFilter(new TextLineCodecFactory(Charset

.forName("UTF-8"), LineDelimiter.WINDOWS.getValue(),

LineDelimiter.WINDOWS.getValue())));

// 添加业务逻辑处理器类

connector.setHandler(new ClientMessageHandler());

IoSession session = null;

try {

ConnectFuture future = connector.connect(new InetSocketAddress(

HOST, PORT));

future.awaitUninterruptibly(); // 等待连接创建完成

session = future.getSession();

session.write("mina");

} catch (Exception e) {

logger.info("客户端链接异常...");

}

session.getCloseFuture().awaitUninterruptibly();

logger.info("Mina要关闭了");

connector.dispose();

}

} 客户端业务处理

package com.boonya.protocol.handler.request;

import org.apache.log4j.Logger;

import org.apache.mina.core.service.IoHandlerAdapter;

import org.apache.mina.core.session.IoSession;

public class ClientMessageHandler extends IoHandlerAdapter {

private static Logger logger = Logger.getLogger(ClientMessageHandler.class);

public void messageReceived(IoSession session, Object message)

throws Exception {

String msg = message.toString();

logger.info("客户端接收到的信息为:" + msg);

}

@Override

public void exceptionCaught(IoSession session, Throwable cause)

throws Exception {

logger.info("客户端发生异常..." + cause);

}

}

2、服务端

package com.boonya.protocol;

import java.net.InetSocketAddress;

import java.nio.charset.Charset;

import org.apache.log4j.Logger;

import org.apache.mina.core.service.IoAcceptor;

import org.apache.mina.core.session.IdleStatus;

import org.apache.mina.filter.codec.ProtocolCodecFilter;

import org.apache.mina.filter.codec.textline.LineDelimiter;

import org.apache.mina.filter.codec.textline.TextLineCodecFactory;

import org.apache.mina.filter.logging.LoggingFilter;

import org.apache.mina.transport.socket.nio.NioSocketAcceptor;

import com.boonya.protocol.handler.response.ServerMessageHandler;

public class Myserver {

private static Logger logger = Logger.getLogger(Myserver.class);

private static int PORT = 8900;

public static void main(String[] args) {

// 创建非阻塞的server端的socket

IoAcceptor acceptor = null;

try {

acceptor = new NioSocketAcceptor();

// 设置日志过滤器

acceptor.getFilterChain().addLast("logger", new LoggingFilter());

acceptor.getFilterChain().addLast( // 添加消息过滤器

"codec",

// Mina自带的根据文本换行符编解码的TextLineCodec过滤器 看到\r\n就认为一个完整的消息结束了

new ProtocolCodecFilter(new TextLineCodecFactory(Charset

.forName("UTF-8"),

LineDelimiter.WINDOWS.getValue(),

LineDelimiter.WINDOWS.getValue())));

// 设置读取数据的缓冲区的大小

acceptor.getSessionConfig().setReadBufferSize(2048);

// 读取通道10s内无操作进入空闲状态

acceptor.getSessionConfig().setIdleTime(IdleStatus.BOTH_IDLE, 10);

// 绑定逻辑处理器

acceptor.setHandler(new ServerMessageHandler());

// 绑定端口

acceptor.bind(new InetSocketAddress(PORT));

logger.info("服务器启动成功.. 端口号为:" + PORT);

} catch (Exception e) {

e.printStackTrace();

}

}

} 服务端业务处理

package com.boonya.protocol.handler.response;

import java.util.Date;

import org.apache.log4j.Logger;

import org.apache.mina.core.service.IoHandlerAdapter;

import org.apache.mina.core.session.IdleStatus;

import org.apache.mina.core.session.IoSession;

public class ServerMessageHandler extends IoHandlerAdapter {

public static Logger logger = Logger.getLogger(ServerMessageHandler.class);

public void sessionCreated(IoSession session) throws Exception {

logger.info("服务端与客户端创建连接");

}

public void sessionOpened(IoSession session) throws Exception {

logger.info("服务器与客户端连接打开...");

}

public void messageReceived(IoSession session, java.lang.Object message)

throws Exception {

String msg = message.toString();

logger.info("服务端接收的数据为:" + msg);

if ("bye".equals(msg)) {// 服务器断开的条件

session.close(true);

}

Date date = new Date();

session.write(date);

}

public void messageSent(IoSession session, Object message) throws Exception {

logger.info("服务端发送消息成功...");

}

public void sessionIdle(IoSession session, IdleStatus status)

throws java.lang.Exception {

logger.info("服务端进入空闲状态...");

}

public void exceptionCaught(IoSession session, Throwable cause)

throws Exception {

logger.info("服务端发送异常..."+cause);

}

public void sessionClosed(IoSession session) throws Exception {

logger.info("关闭连接...");

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值