1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package org.jboss.netty.example.qotm;
17
18 import org.jboss.netty.bootstrap.ConnectionlessBootstrap;
19 import org.jboss.netty.channel.ChannelPipeline;
20 import org.jboss.netty.channel.ChannelPipelineFactory;
21 import org.jboss.netty.channel.Channels;
22 import org.jboss.netty.channel.FixedReceiveBufferSizePredictorFactory;
23 import org.jboss.netty.channel.socket.DatagramChannel;
24 import org.jboss.netty.channel.socket.nio.NioDatagramChannelFactory;
25 import org.jboss.netty.handler.codec.string.StringDecoder;
26 import org.jboss.netty.handler.codec.string.StringEncoder;
27 import org.jboss.netty.util.CharsetUtil;
28
29 import java.net.InetSocketAddress;
30 import java.util.concurrent.Executors;
31
32
33
34
35
36
37
38 public final class QuoteOfTheMomentClient {
39
40 static final int PORT = Integer.parseInt(System.getProperty("port", "7686"));
41
42 public static void main(String[] args) throws Exception {
43 ConnectionlessBootstrap b = new ConnectionlessBootstrap(
44 new NioDatagramChannelFactory(Executors.newCachedThreadPool()));
45
46 try {
47
48 b.setPipelineFactory(new ChannelPipelineFactory() {
49 public ChannelPipeline getPipeline() {
50 return Channels.pipeline(
51 new StringEncoder(CharsetUtil.ISO_8859_1),
52 new StringDecoder(CharsetUtil.ISO_8859_1),
53 new QuoteOfTheMomentClientHandler());
54 }
55 });
56
57
58 b.setOption("broadcast", "true");
59
60
61
62
63
64
65
66
67
68
69
70 b.setOption(
71 "receiveBufferSizePredictorFactory",
72 new FixedReceiveBufferSizePredictorFactory(1024));
73
74 DatagramChannel c = (DatagramChannel) b.bind(new InetSocketAddress(0));
75
76
77 c.write("QOTM?", new InetSocketAddress("255.255.255.255", PORT));
78
79
80
81
82 if (!c.getCloseFuture().await(5000)) {
83 System.err.println("QOTM request timed out.");
84 c.close().sync();
85 }
86 } finally {
87 b.releaseExternalResources();
88 }
89 }
90 }