1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package io.netty.example.proxy;
17
18 import io.netty.bootstrap.ServerBootstrap;
19 import io.netty.channel.ChannelOption;
20 import io.netty.channel.EventLoopGroup;
21 import io.netty.channel.nio.NioEventLoopGroup;
22 import io.netty.channel.socket.nio.NioServerSocketChannel;
23 import io.netty.handler.logging.LogLevel;
24 import io.netty.handler.logging.LoggingHandler;
25
26 public final class HexDumpProxy {
27
28 static final int LOCAL_PORT = Integer.parseInt(System.getProperty("localPort", "8443"));
29 static final String REMOTE_HOST = System.getProperty("remoteHost", "www.google.com");
30 static final int REMOTE_PORT = Integer.parseInt(System.getProperty("remotePort", "443"));
31
32 public static void main(String[] args) throws Exception {
33 System.err.println("Proxying *:" + LOCAL_PORT + " to " + REMOTE_HOST + ':' + REMOTE_PORT + " ...");
34
35
36 EventLoopGroup bossGroup = new NioEventLoopGroup(1);
37 EventLoopGroup workerGroup = new NioEventLoopGroup();
38 try {
39 ServerBootstrap b = new ServerBootstrap();
40 b.group(bossGroup, workerGroup)
41 .channel(NioServerSocketChannel.class)
42 .handler(new LoggingHandler(LogLevel.INFO))
43 .childHandler(new HexDumpProxyInitializer(REMOTE_HOST, REMOTE_PORT))
44 .childOption(ChannelOption.AUTO_READ, false)
45 .bind(LOCAL_PORT).sync().channel().closeFuture().sync();
46 } finally {
47 bossGroup.shutdownGracefully();
48 workerGroup.shutdownGracefully();
49 }
50 }
51 }