1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package io.netty.example.file;
17
18 import io.netty.bootstrap.ServerBootstrap;
19 import io.netty.channel.ChannelFuture;
20 import io.netty.channel.ChannelInitializer;
21 import io.netty.channel.ChannelOption;
22 import io.netty.channel.ChannelPipeline;
23 import io.netty.channel.EventLoopGroup;
24 import io.netty.channel.nio.NioEventLoopGroup;
25 import io.netty.channel.socket.SocketChannel;
26 import io.netty.channel.socket.nio.NioServerSocketChannel;
27 import io.netty.example.util.ServerUtil;
28 import io.netty.handler.codec.LineBasedFrameDecoder;
29 import io.netty.handler.codec.string.StringDecoder;
30 import io.netty.handler.codec.string.StringEncoder;
31 import io.netty.handler.logging.LogLevel;
32 import io.netty.handler.logging.LoggingHandler;
33 import io.netty.handler.ssl.SslContext;
34 import io.netty.handler.stream.ChunkedWriteHandler;
35 import io.netty.util.CharsetUtil;
36
37
38
39
40 public final class FileServer {
41
42 static final boolean SSL = System.getProperty("ssl") != null;
43
44 static final int PORT = Integer.parseInt(System.getProperty("port", SSL? "8992" : "8023"));
45
46 public static void main(String[] args) throws Exception {
47
48 final SslContext sslCtx = ServerUtil.buildSslContext();
49
50
51 EventLoopGroup bossGroup = new NioEventLoopGroup(1);
52 EventLoopGroup workerGroup = new NioEventLoopGroup();
53 try {
54 ServerBootstrap b = new ServerBootstrap();
55 b.group(bossGroup, workerGroup)
56 .channel(NioServerSocketChannel.class)
57 .option(ChannelOption.SO_BACKLOG, 100)
58 .handler(new LoggingHandler(LogLevel.INFO))
59 .childHandler(new ChannelInitializer<SocketChannel>() {
60 @Override
61 public void initChannel(SocketChannel ch) throws Exception {
62 ChannelPipeline p = ch.pipeline();
63 if (sslCtx != null) {
64 p.addLast(sslCtx.newHandler(ch.alloc()));
65 }
66 p.addLast(
67 new StringEncoder(CharsetUtil.UTF_8),
68 new LineBasedFrameDecoder(8192),
69 new StringDecoder(CharsetUtil.UTF_8),
70 new ChunkedWriteHandler(),
71 new FileServerHandler());
72 }
73 });
74
75
76 ChannelFuture f = b.bind(PORT).sync();
77
78
79 f.channel().closeFuture().sync();
80 } finally {
81
82 bossGroup.shutdownGracefully();
83 workerGroup.shutdownGracefully();
84 }
85 }
86 }