Mina第一次听到这个名称的时候,我以为是个MM的名字米娜,后来才知道…

Apache MINA(Multipurpose Infrastructure for Network Applications)

官网http://mina.apache.org/

是 Apache 组织一个较新的项目,它为开发高性能和高可用性的网络应用程序提供了非常便利的框架。当前发行的 MINA 版本支持基于 Java NIO 技术的 TCP/UDP 应用程序开发、串口通讯程序(只在最新的预览版中提供),MINA 所支持的功能也在进一步的扩展中。 目前正在使用 MINA 的软件包括有:Apache Directory Project、AsyncWeb、AMQP(Advanced Message Queuing Protocol)、RED5 Server(Macromedia Flash Media RTMP)、ObjectRADIUS、Openfire 等等。

本文就介绍入门mina的入门,

参考文档http://mina.apache.org/mina-project/quick-start-guide.html

第一步、定义MinaTimeServer.java mina服务端

/**

*

*/

package com.figo.onlineshop.test;

import java.io.IOException;

import java.net.InetSocketAddress;

import java.nio.charset.Charset;

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.TextLineCodecFactory;

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

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

/**

* @author zhuzhifei

*

*/

public class MinaTimeServer {

private static final int PORT = 9123;

/**

* @param args

*/

public static void main(String[] args) {

// TODO Auto-generated method stub

//定义socket接收器

IoAcceptor acceptor = new NioSocketAcceptor();

//添加日志记录

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

//添加编码解码器

acceptor.getFilterChain().addLast( "codec", new ProtocolCodecFilter( new TextLineCodecFactory( Charset.forName( "UTF-8" ))));

//添加处理器(用于接收数据后处理处理数据逻辑)

acceptor.setHandler(  new TimeServerHandler() );

//设置读取数据缓存单位byte

acceptor.getSessionConfig().setReadBufferSize( 2048 );

//设置多长时间后接收器开始空闲

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

try {

//绑定某个端口,作为数据入口

acceptor.bind( new InetSocketAddress(PORT) );

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

第二步、定义消息处理器TimeServerHandler.java

/**

*

*/

package com.figo.onlineshop.test;

import java.util.Date;

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

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

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

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

/**

* @author zhuzhifei

*

*/

//必须继承IoHandlerAdapter

public class TimeServerHandler extends IoHandlerAdapter {

private final Logger logger = LoggerFactory.getLogger(MinaTimeServer.class);

//补抓异常

@Override

public void exceptionCaught(IoSession session, Throwable cause)

throws Exception {

// TODO Auto-generated method stub

super.exceptionCaught(session, cause);

}

//获取客户端消息后处理逻辑

@Override

public void messageReceived(IoSession session, Object message)

throws Exception {

// TODO Auto-generated method stub

super.messageReceived(session, message);

String str = message.toString();

if( str.trim().equalsIgnoreCase("quit") ) {

session.close(true);

return;

}

Date date = new Date();

session.write( "current time:"+date.toString() );//该消息将返回给客户端

System.out.println("Message Received:"+str);

logger.info(date.toString()+"Message Received:"+str);//日志没有输出why?

}

//发送消息

@Override

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

// TODO Auto-generated method stub

super.messageSent(session, message);

}

//当前会话关闭

@Override

public void sessionClosed(IoSession session) throws Exception {

// TODO Auto-generated method stub

super.sessionClosed(session);

}

//创建会话

@Override

public void sessionCreated(IoSession session) throws Exception {

// TODO Auto-generated method stub

super.sessionCreated(session);

}

//会话空闲

@Override

public void sessionIdle(IoSession session, IdleStatus status)

throws Exception {

// TODO Auto-generated method stub

super.sessionIdle(session, status);

System.out.println( "IDLE " + session.getIdleCount( status ));

}

//打开会话

@Override

public void sessionOpened(IoSession session) throws Exception {

// TODO Auto-generated method stub

super.sessionOpened(session);

}

}

第三步、模拟客户端tcp调用

MinaTimeServer.java run as java Application后

C:\Documents and Settings\zhuzhifei>telnet 127.0.0.1 9123 连上服务器

客户端输入:abc后

服务端接收到:

2012-12-25 18:26:52 INFO  com.figo.onlineshop.test.MinaTimeServer - Tue Dec 25 18:26:52 CST 2012Message Received:abc

客户端显示:current time:Tue Dec 25 18:26:52 CST 2012

Apache Mina入门的更多相关文章

  1. Apache Mina入门实例

    一.mina是啥 ApacheMINA是一个网络应用程序框架,用来帮助用户简单地开发高性能和高可扩展性的网络应用程序.它提供了一个通过Java NIO在不同的传输例如TCP/IP和UDP/IP上抽象的 ...

  2. Apache Mina 入门实例

    这个教程是介绍使用Mina搭建基础示例.这个教程内容是以创建一个时间服务器. 以下是这个教程需要准备的东西: MINA 2.0.7 Core JDK 1.5 或更高 SLF4J 1.3.0 或更高 L ...

  3. JAVA通信系列二:mina入门总结

    一.学习资料 Mina入门实例(一) http://www.cnblogs.com/juepei/p/3939119.html Mina入门教程(二)----Spring4 集成Mina http:/ ...

  4. Mina入门:mina版之HelloWorld

    一,前言: 在完成上篇文章<Mina入门:Java NIO框架Mina.Netty.Grizzly简介与对比>之后,我们现在可以正式切入Mina入门学习了. 二,搭建项目结构与解决项目依赖 ...

  5. Apache Mina -2

    我们可以了解到 mina是个异步通信框架,一般使用场景是服务端开发,长连接.异步通信使用mina是及其方便的.不多说,看例子. 本次mina 使用的例子是使用maven构建的,过程中需要用到的jar包 ...

  6. Mina入门:mina版之HelloWorld[z]

    Mina入门:mina版之HelloWorld [z] 一,前言: 在完成上篇文章<Mina入门:Java NIO框架Mina.Netty.Grizzly简介与对比>之后,我们现在可以正式 ...

  7. Mina入门实例(一)

    mina现在用的很多了,之前也有用到,但是毕竟不熟悉,于是查了一些资料,做了一些总结.看代码是最直观的,比什么长篇大论都要好.不过其中重要的理论,也要理解下. 首先是环境,程序运行需要几个包,这里用m ...

  8. Mina入门教程(二)----Spring4 集成Mina

    在spring和mina集成的时候,要十分注意一个问题:版本. 这是一个非常严重的问题,mina官网的demo没错,网上很多网友总结的代码也是对的,但是很多人将mina集成到spring中的时候,总是 ...

  9. Apache MiNa 实现多人聊天室

    Apache MiNa 实现多人聊天室 开发环境: System:Windows JavaSDK:1.6 IDE:eclipse.MyEclipse 6.6 开发依赖库: Jdk1.4+.mina-c ...

随机推荐

  1. springMVC源码分析--HttpMessageConverter写write操作(三)

    上一篇博客springMVC源码分析--HttpMessageConverter参数read操作中我们已经简单介绍了参数值转换的read操作,接下来我们介绍一下返回值的处理操作.同样返回值的操作操作也 ...

  2. js中的异步[Important]

    js作为前端最主流的语言,主要处理页面显示变化(mutation)和异步(asynchronicity), js语言的基本要素和使用惯例的演化大都围绕着这两大主题,两者均值得总结和思考的主题, 这里先 ...

  3. CCF201712真题

    试题编号: 201712-1 试题名称: 最小差值 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 给定n个数,请找出其中相差(差的绝对值)最小的两个数,输出它们的差值的绝对值 ...

  4. abp zero 4.3 发布

    Demo URL: http://abpzerodemo.demo.aspnetzero.com Username: systemPassword: 123456 需要源码,请加QQ:3833-255 ...

  5. spring boot配置文件中 spring.mvc.static-path-pattern 配置项

    spring boot项目中的静态资源文件存放在static文件下面,当通过浏览器访问这些静态文件时,发现必须要添加static作为前缀才能访问,折腾了一番后发现,这个前缀跟 spring.mvc.s ...

  6. HDU - 4465 期望 + 取log优化

    思路:这个求期望的公式很容易得到,但是在算的时候我们会遇到一个问题,就是组合数太大了根本存不下, 这时候就可以在计算的时候都取log,最后复原...  以前没遇到过.. #include<bit ...

  7. python之markdown转html

    python之markdown转html 为了方便,定义一个markdown转html的函数,直接调用即可 import markdown def md2html(mdstr): exts = ['m ...

  8. 百度地图API--Key的获得

    [开年后花了半个月的时间学习了百度地图API开发,准备投入项目中,学习的过程中写了一些简单的总结,在部门内部做了一个简单的分享培训,这里希望将自己的仅有的一点点关于百度地图API的收获分享给社区,整个 ...

  9. thinkphp3.2中开启静态缓存后对404页面的处理方法

    静态缓存很实用但是有时有些不需要静态缓存,如404页面,第一次访问返回404页面并缓存,第二次换回的状态就是200,属于正常访问,虽然人眼可以看出是404页面,但是搜索引擎不会的,而是把这个页面当成正 ...

  10. js根据IP跳转

    <script language="javascript" type="text/javascript" src="http://int.dpo ...