01: /*
02: * Licensed to the Apache Software Foundation (ASF) under one
03: * or more contributor license agreements. See the NOTICE file
04: * distributed with this work for additional information
05: * regarding copyright ownership. The ASF licenses this file
06: * to you under the Apache License, Version 2.0 (the
07: * "License"); you may not use this file except in compliance
08: * with the License. You may obtain a copy of the License at
09: *
10: * http://www.apache.org/licenses/LICENSE-2.0
11: *
12: * Unless required by applicable law or agreed to in writing,
13: * software distributed under the License is distributed on an
14: * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15: * KIND, either express or implied. See the License for the
16: * specific language governing permissions and limitations
17: * under the License.
18: *
19: */
20: package org.apache.mina.example.sumup;
21:
22: import java.net.InetSocketAddress;
23:
24: import org.apache.mina.example.sumup.codec.SumUpProtocolCodecFactory;
25: import org.apache.mina.filter.codec.ProtocolCodecFilter;
26: import org.apache.mina.filter.codec.serialization.ObjectSerializationCodecFactory;
27: import org.apache.mina.filter.logging.LoggingFilter;
28: import org.apache.mina.transport.socket.nio.NioSocketAcceptor;
29:
30: /**
31: * (<strong>Entry Point</strong>) Starts SumUp server.
32: *
33: * @author The Apache MINA Project (dev@mina.apache.org)
34: * @version $Rev: 600461 $, $Date: 2007-12-03 02:55:52 -0700 (Mon, 03 Dec 2007) $
35: */
36: public class Server {
37: private static final int SERVER_PORT = 8080;
38:
39: // Set this to false to use object serialization instead of custom codec.
40: private static final boolean USE_CUSTOM_CODEC = true;
41:
42: public static void main(String[] args) throws Throwable {
43: NioSocketAcceptor acceptor = new NioSocketAcceptor();
44:
45: // Prepare the service configuration.
46: if (USE_CUSTOM_CODEC) {
47: acceptor.getFilterChain().addLast(
48: "codec",
49: new ProtocolCodecFilter(
50: new SumUpProtocolCodecFactory(true)));
51: } else {
52: acceptor.getFilterChain().addLast(
53: "codec",
54: new ProtocolCodecFilter(
55: new ObjectSerializationCodecFactory()));
56: }
57: acceptor.getFilterChain()
58: .addLast("logger", new LoggingFilter());
59:
60: acceptor.setHandler(new ServerSessionHandler());
61: acceptor.bind(new InetSocketAddress(SERVER_PORT));
62:
63: System.out.println("Listening on port " + SERVER_PORT);
64: }
65: }
|