欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

apache mina (异步连接框架)介绍 MinaApache框架log4jSocket

程序员文章站 2024-01-13 09:17:58
...
一、介绍
mina(Multipurpose Infrastructure for Network Applications) 是apache的*项目之一,用于构造异步连接的各种网络应用
二、最简单的使用实例
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocketpackage aicu.mina;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import java.io.IOException;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import java.net.InetSocketAddress;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import java.nio.charset.Charset;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.common.ByteBuffer;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.common.IoAcceptor;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.common.SimpleByteBufferAllocator;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.filter.LoggingFilter;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.filter.codec.ProtocolCodecFilter;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.filter.codec.textline.TextLineCodecFactory;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.transport.socket.nio.SocketAcceptor;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.transport.socket.nio.SocketAcceptorConfig;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocketapache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
public class MinaTimeServer apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket{
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket    
private static final int PORT = 9123;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocketapache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket    
public static void main(String[] args) throws IOException apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket{
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        
//设置buffer
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
        ByteBuffer.setUseDirectBuffers(false);
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        ByteBuffer.setAllocator(
new SimpleByteBufferAllocator());
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        
//定义acceptor
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
        IoAcceptor acceptor = new SocketAcceptor();
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        
//定义config
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
        SocketAcceptorConfig cfg = new SocketAcceptorConfig();
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        
//设置config,加入filter
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
        cfg.getSessionConfig().setReuseAddress( true );
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        cfg.getFilterChain().addLast( 
"logger"new LoggingFilter() );
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        cfg.getFilterChain().addLast( 
"codec"new ProtocolCodecFilter( new TextLineCodecFactory( Charset.forName( "UTF-8" ))));
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        
//加入port handler cfg
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
        acceptor.bind( new InetSocketAddress(PORT), new TimeServerHandler(), cfg);
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        System.out.println(
"MINA Time server started.");
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket    }

apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket}

对应的handler ,handler的作用是在对应的网事件的处理代码
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocketpackage aicu.mina;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import java.util.Date;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.common.IdleStatus;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.common.IoHandlerAdapter;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.common.IoSession;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.common.TransportType;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
import org.apache.mina.transport.socket.nio.SocketSessionConfig;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocketapache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
public class TimeServerHandler extends IoHandlerAdapter apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket{
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocketapache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket    
public void exceptionCaught(IoSession session, Throwable t) throws Exception apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket{
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        t.printStackTrace();
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        session.close();
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket    }

apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocketapache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket    
public void messageReceived(IoSession session, Object msg) throws Exception apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket{
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        String str 
= msg.toString();
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        
//如果是quit就关闭session退出
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocketapache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
        if( str.trim().equalsIgnoreCase("quit") ) apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket{
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket            session.close();
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket            
return;
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        }

apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        
//否则打印当前日期
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
        Date date = new Date();
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        session.write( date.toString() );
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        System.out.println(
"Message writtenapache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket");
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket    }

apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocketapache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket    
public void sessionCreated(IoSession session) throws Exception apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket{
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        System.out.println(
"Session createdapache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket");
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        
if( session.getTransportType() == TransportType.SOCKET )
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket            ((SocketSessionConfig) session.getConfig() ).setReceiveBufferSize( 
2048 );
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket        session.setIdleTime( IdleStatus.BOTH_IDLE, 
10 );
apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket    }

apache mina (异步连接框架)介绍 
            
    
    
        MinaApache框架log4jSocket}
三、使用方法:
编译上边两个类(需要加入mina的jar文件),然后运行terminalServer
开始->运行->cmd进入控制台
telnet 127.0.0.1 9123
输入hello
得到当前日期
输入quit关闭session。