MINA的第一个小小的例子

今天在别人的博客上看到过Apache的NIO框架MINA比较感兴趣,所以就参考别人的列子,自己动手配置运行了一下,感觉真是很爽。
1:首先下载MINA2的jar与其相关的jar包。
导入需要的jar包,如图。
[img]http://dl.iteye.com/upload/attachment/0067/7191/1dace8ce-ac9e-357f-8451-4c18d90b75cc.jpg[/img]
2:构建CalculatorHandler类


import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
import javax.script.ScriptException;

import org.apache.log4j.Logger;
import org.apache.mina.core.service.IoHandlerAdapter;
import org.apache.mina.core.session.IoSession;


public class CalculatorHandler extends IoHandlerAdapter {
private static final Logger LOGGER = Logger.getLogger(CalculatorHandler.class);

private ScriptEngine jsEngine = null;

public CalculatorHandler() {
ScriptEngineManager sfm = new ScriptEngineManager();
jsEngine = sfm.getEngineByName("JavaScript");
if (jsEngine == null) {
throw new RuntimeException("找不到 JavaScript 引擎。");
}
}

public void exceptionCaught(IoSession session, Throwable cause)
throws Exception {
LOGGER.warn(cause.getMessage(), cause);
}

public void messageReceived(IoSession session, Object message)
throws Exception {
String expression = message.toString();
if ("quit".equalsIgnoreCase(expression.trim())) {
session.close(true);
return;
}
try {
Object result = jsEngine.eval(expression);
session.write(result.toString());
} catch (ScriptException e) {
LOGGER.warn(e.getMessage(), e);
session.write("Wrong expression, try again.");
}
}
}



3:构建CalculatorServer类

import java.io.IOException;
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.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;


public class CalculatorServer {
private static final int PORT = 10010;

private static final Logger LOGGER = Logger.getLogger(CalculatorServer.class);

public static void main(String[] args) throws IOException {
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 CalculatorHandler());
acceptor.bind(new InetSocketAddress(PORT));

LOGGER.info("计算器服务已启动,端口是" + PORT);
}
}




4: 使用 Telnet 工具测试计算器服务
[img]http://dl.iteye.com/upload/attachment/0067/7195/b380c516-0d87-37ae-a6dd-e134fb7b552e.jpg[/img]

运行后的界面

[img]http://dl.iteye.com/upload/attachment/0067/7203/ff9b098d-1b86-34a2-aa93-eea1cf3cced9.jpg[/img]

5:因为小弟刚学,这是第一个例子感觉比较新奇,希望大神们能够分享这方面的学习资料
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值