[190] | 1 | <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
|
---|
| 2 | <!-- /home/espenr/tmp/qt-3.3.8-espenr-2499/qt-x11-free-3.3.8/examples/network/clientserver/clientserver.doc:5 -->
|
---|
| 3 | <html>
|
---|
| 4 | <head>
|
---|
| 5 | <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
|
---|
| 6 | <title>A small client-server example</title>
|
---|
| 7 | <style type="text/css"><!--
|
---|
| 8 | fn { margin-left: 1cm; text-indent: -1cm; }
|
---|
| 9 | a:link { color: #004faf; text-decoration: none }
|
---|
| 10 | a:visited { color: #672967; text-decoration: none }
|
---|
| 11 | body { background: #ffffff; color: black; }
|
---|
| 12 | --></style>
|
---|
| 13 | </head>
|
---|
| 14 | <body>
|
---|
| 15 |
|
---|
| 16 | <table border="0" cellpadding="0" cellspacing="0" width="100%">
|
---|
| 17 | <tr bgcolor="#E5E5E5">
|
---|
| 18 | <td valign=center>
|
---|
| 19 | <a href="index.html">
|
---|
| 20 | <font color="#004faf">Home</font></a>
|
---|
| 21 | | <a href="classes.html">
|
---|
| 22 | <font color="#004faf">All Classes</font></a>
|
---|
| 23 | | <a href="mainclasses.html">
|
---|
| 24 | <font color="#004faf">Main Classes</font></a>
|
---|
| 25 | | <a href="annotated.html">
|
---|
| 26 | <font color="#004faf">Annotated</font></a>
|
---|
| 27 | | <a href="groups.html">
|
---|
| 28 | <font color="#004faf">Grouped Classes</font></a>
|
---|
| 29 | | <a href="functions.html">
|
---|
| 30 | <font color="#004faf">Functions</font></a>
|
---|
| 31 | </td>
|
---|
| 32 | <td align="right" valign="center"><img src="logo32.png" align="right" width="64" height="32" border="0"></td></tr></table><h1 align=center>A small client-server example</h1>
|
---|
| 33 |
|
---|
| 34 |
|
---|
| 35 | <p>
|
---|
| 36 | <p> This example shows how two programs can communicate using sockets.
|
---|
| 37 | <p> Two simple example programs are provided, a client program and a
|
---|
| 38 | server program. Both use the <a href="qsocket.html">QSocket</a> class, and the server also uses
|
---|
| 39 | <a href="qserversocket.html">QServerSocket</a> class.
|
---|
| 40 | <p> The server listens on port number 4242 and accepts incoming connections.
|
---|
| 41 | It sends back every line it receives from the client, prepended with
|
---|
| 42 | the line number.
|
---|
| 43 | <p> The client tries to connect to the server on the host specified on the
|
---|
| 44 | command line or to localhost if no command line arguments are
|
---|
| 45 | specified. You can send single lines to the server.
|
---|
| 46 | <p> <hr>
|
---|
| 47 | <p> Implementation server (server.cpp):
|
---|
| 48 | <p> <pre>/****************************************************************************
|
---|
| 49 | ** $Id: clientserver-example.html 2051 2007-02-21 10:04:20Z chehrlic $
|
---|
| 50 | **
|
---|
| 51 | ** Copyright (C) 1992-2007 Trolltech ASA. All rights reserved.
|
---|
| 52 | **
|
---|
| 53 | ** This file is part of an example program for Qt. This example
|
---|
| 54 | ** program may be used, distributed and modified without limitation.
|
---|
| 55 | **
|
---|
| 56 | *****************************************************************************/
|
---|
| 57 |
|
---|
| 58 | #include <<a href="qsocket-h.html">qsocket.h</a>>
|
---|
| 59 | #include <<a href="qserversocket-h.html">qserversocket.h</a>>
|
---|
| 60 | #include <<a href="qapplication-h.html">qapplication.h</a>>
|
---|
| 61 | #include <<a href="qvbox-h.html">qvbox.h</a>>
|
---|
| 62 | #include <<a href="qtextview-h.html">qtextview.h</a>>
|
---|
| 63 | #include <<a href="qlabel-h.html">qlabel.h</a>>
|
---|
| 64 | #include <<a href="qpushbutton-h.html">qpushbutton.h</a>>
|
---|
| 65 | #include <<a href="qtextstream-h.html">qtextstream.h</a>>
|
---|
| 66 |
|
---|
| 67 | #include <stdlib.h>
|
---|
| 68 |
|
---|
| 69 |
|
---|
| 70 | /*
|
---|
| 71 | The ClientSocket class provides a socket that is connected with a client.
|
---|
| 72 | For every client that connects to the server, the server creates a new
|
---|
| 73 | instance of this class.
|
---|
| 74 | */
|
---|
| 75 | class ClientSocket : public <a href="qsocket.html">QSocket</a>
|
---|
| 76 | {
|
---|
| 77 | <a href="metaobjects.html#Q_OBJECT">Q_OBJECT</a>
|
---|
| 78 | public:
|
---|
| 79 | ClientSocket( int sock, QObject *parent=0, const char *name=0 ) :
|
---|
| 80 | <a href="qsocket.html">QSocket</a>( parent, name )
|
---|
| 81 | {
|
---|
| 82 | line = 0;
|
---|
| 83 | connect( this, SIGNAL(readyRead()),
|
---|
| 84 | SLOT(readClient()) );
|
---|
| 85 | connect( this, SIGNAL(connectionClosed()),
|
---|
| 86 | SLOT(deleteLater()) );
|
---|
| 87 | setSocket( sock );
|
---|
| 88 | }
|
---|
| 89 |
|
---|
| 90 | ~ClientSocket()
|
---|
| 91 | {
|
---|
| 92 | }
|
---|
| 93 |
|
---|
| 94 | signals:
|
---|
| 95 | void logText( const <a href="qstring.html">QString</a>& );
|
---|
| 96 |
|
---|
| 97 | private slots:
|
---|
| 98 | void readClient()
|
---|
| 99 | {
|
---|
| 100 | <a href="qtextstream.html">QTextStream</a> ts( this );
|
---|
| 101 | while ( canReadLine() ) {
|
---|
| 102 | <a name="x787"></a> <a href="qstring.html">QString</a> str = ts.<a href="qtextstream.html#readLine">readLine</a>();
|
---|
| 103 | emit logText( tr("Read: '%1'\n").arg(str) );
|
---|
| 104 |
|
---|
| 105 | ts << line << ": " << str << endl;
|
---|
| 106 | emit logText( tr("Wrote: '%1: %2'\n").arg(line).arg(str) );
|
---|
| 107 |
|
---|
| 108 | line++;
|
---|
| 109 | }
|
---|
| 110 | }
|
---|
| 111 |
|
---|
| 112 | private:
|
---|
| 113 | int line;
|
---|
| 114 | };
|
---|
| 115 |
|
---|
| 116 |
|
---|
| 117 | /*
|
---|
| 118 | The SimpleServer class handles new connections to the server. For every
|
---|
| 119 | client that connects, it creates a new ClientSocket -- that instance is now
|
---|
| 120 | responsible for the communication with that client.
|
---|
| 121 | */
|
---|
| 122 | class SimpleServer : public <a href="qserversocket.html">QServerSocket</a>
|
---|
| 123 | {
|
---|
| 124 | Q_OBJECT
|
---|
| 125 | public:
|
---|
| 126 | SimpleServer( <a href="qobject.html">QObject</a>* parent=0 ) :
|
---|
| 127 | <a href="qserversocket.html">QServerSocket</a>( 4242, 1, parent )
|
---|
| 128 | {
|
---|
| 129 | if ( !ok() ) {
|
---|
| 130 | <a href="qapplication.html#qWarning">qWarning</a>("Failed to bind to port 4242");
|
---|
| 131 | exit(1);
|
---|
| 132 | }
|
---|
| 133 | }
|
---|
| 134 |
|
---|
| 135 | ~SimpleServer()
|
---|
| 136 | {
|
---|
| 137 | }
|
---|
| 138 |
|
---|
| 139 | void newConnection( int socket )
|
---|
| 140 | {
|
---|
| 141 | ClientSocket *s = new ClientSocket( socket, this );
|
---|
| 142 | emit newConnect( s );
|
---|
| 143 | }
|
---|
| 144 |
|
---|
| 145 | signals:
|
---|
| 146 | void newConnect( ClientSocket* );
|
---|
| 147 | };
|
---|
| 148 |
|
---|
| 149 |
|
---|
| 150 | /*
|
---|
| 151 | The ServerInfo class provides a small GUI for the server. It also creates the
|
---|
| 152 | SimpleServer and as a result the server.
|
---|
| 153 | */
|
---|
| 154 | class ServerInfo : public <a href="qvbox.html">QVBox</a>
|
---|
| 155 | {
|
---|
| 156 | Q_OBJECT
|
---|
| 157 | public:
|
---|
| 158 | ServerInfo()
|
---|
| 159 | {
|
---|
| 160 | SimpleServer *server = new SimpleServer( this );
|
---|
| 161 |
|
---|
| 162 | <a href="qstring.html">QString</a> itext = tr(
|
---|
| 163 | "This is a small server example.\n"
|
---|
| 164 | "Connect with the client now."
|
---|
| 165 | );
|
---|
| 166 | <a href="qlabel.html">QLabel</a> *lb = new <a href="qlabel.html">QLabel</a>( itext, this );
|
---|
| 167 | <a name="x784"></a> lb-><a href="qlabel.html#setAlignment">setAlignment</a>( AlignHCenter );
|
---|
| 168 | infoText = new <a href="qtextview.html">QTextView</a>( this );
|
---|
| 169 | <a href="qpushbutton.html">QPushButton</a> *quit = new <a href="qpushbutton.html">QPushButton</a>( tr("Quit") , this );
|
---|
| 170 |
|
---|
| 171 | connect( server, SIGNAL(newConnect(ClientSocket*)),
|
---|
| 172 | SLOT(newConnect(ClientSocket*)) );
|
---|
| 173 | connect( quit, SIGNAL(<a href="qbutton.html#clicked">clicked</a>()), qApp,
|
---|
| 174 | SLOT(<a href="qapplication.html#quit">quit</a>()) );
|
---|
| 175 | }
|
---|
| 176 |
|
---|
| 177 | ~ServerInfo()
|
---|
| 178 | {
|
---|
| 179 | }
|
---|
| 180 |
|
---|
| 181 | private slots:
|
---|
| 182 | void newConnect( ClientSocket *s )
|
---|
| 183 | {
|
---|
| 184 | <a name="x786"></a> infoText-><a href="qtextedit.html#append">append</a>( tr("New connection\n") );
|
---|
| 185 | connect( s, SIGNAL(logText(const <a href="qstring.html">QString</a>&)),
|
---|
| 186 | infoText, SLOT(<a href="qtextedit.html#append">append</a>(const <a href="qstring.html">QString</a>&)) );
|
---|
| 187 | <a name="x785"></a> connect( s, SIGNAL(<a href="qsocket.html#connectionClosed">connectionClosed</a>()),
|
---|
| 188 | SLOT(connectionClosed()) );
|
---|
| 189 | }
|
---|
| 190 |
|
---|
| 191 | void connectionClosed()
|
---|
| 192 | {
|
---|
| 193 | infoText-><a href="qtextedit.html#append">append</a>( tr("Client closed connection\n") );
|
---|
| 194 | }
|
---|
| 195 |
|
---|
| 196 | private:
|
---|
| 197 | <a href="qtextview.html">QTextView</a> *infoText;
|
---|
| 198 | };
|
---|
| 199 |
|
---|
| 200 |
|
---|
| 201 | int main( int argc, char** argv )
|
---|
| 202 | {
|
---|
| 203 | <a href="qapplication.html">QApplication</a> app( argc, argv );
|
---|
| 204 | ServerInfo info;
|
---|
| 205 | app.<a href="qapplication.html#setMainWidget">setMainWidget</a>( &info );
|
---|
| 206 | info.<a href="qwidget.html#show">show</a>();
|
---|
| 207 | return app.<a href="qapplication.html#exec">exec</a>();
|
---|
| 208 | }
|
---|
| 209 |
|
---|
| 210 | #include "server.moc"
|
---|
| 211 | </pre>
|
---|
| 212 |
|
---|
| 213 | <p> <hr>
|
---|
| 214 | <p> Implementation client (client.cpp):
|
---|
| 215 | <p> <pre>/****************************************************************************
|
---|
| 216 | ** $Id: clientserver-example.html 2051 2007-02-21 10:04:20Z chehrlic $
|
---|
| 217 | **
|
---|
| 218 | ** Copyright (C) 1992-2007 Trolltech ASA. All rights reserved.
|
---|
| 219 | **
|
---|
| 220 | ** This file is part of an example program for Qt. This example
|
---|
| 221 | ** program may be used, distributed and modified without limitation.
|
---|
| 222 | **
|
---|
| 223 | *****************************************************************************/
|
---|
| 224 |
|
---|
| 225 | #include <<a href="qsocket-h.html">qsocket.h</a>>
|
---|
| 226 | #include <<a href="qapplication-h.html">qapplication.h</a>>
|
---|
| 227 | #include <<a href="qvbox-h.html">qvbox.h</a>>
|
---|
| 228 | #include <<a href="qhbox-h.html">qhbox.h</a>>
|
---|
| 229 | #include <<a href="qtextview-h.html">qtextview.h</a>>
|
---|
| 230 | #include <<a href="qlineedit-h.html">qlineedit.h</a>>
|
---|
| 231 | #include <<a href="qlabel-h.html">qlabel.h</a>>
|
---|
| 232 | #include <<a href="qpushbutton-h.html">qpushbutton.h</a>>
|
---|
| 233 | #include <<a href="qtextstream-h.html">qtextstream.h</a>>
|
---|
| 234 |
|
---|
| 235 |
|
---|
| 236 | class Client : public <a href="qvbox.html">QVBox</a>
|
---|
| 237 | {
|
---|
| 238 | Q_OBJECT
|
---|
| 239 | public:
|
---|
| 240 | Client( const <a href="qstring.html">QString</a> &host, Q_UINT16 port )
|
---|
| 241 | {
|
---|
| 242 | // GUI layout
|
---|
| 243 | infoText = new <a href="qtextview.html">QTextView</a>( this );
|
---|
| 244 | <a href="qhbox.html">QHBox</a> *hb = new <a href="qhbox.html">QHBox</a>( this );
|
---|
| 245 | inputText = new <a href="qlineedit.html">QLineEdit</a>( hb );
|
---|
| 246 | <a href="qpushbutton.html">QPushButton</a> *send = new <a href="qpushbutton.html">QPushButton</a>( tr("Send") , hb );
|
---|
| 247 | <a href="qpushbutton.html">QPushButton</a> *close = new <a href="qpushbutton.html">QPushButton</a>( tr("Close connection") , this );
|
---|
| 248 | <a href="qpushbutton.html">QPushButton</a> *quit = new <a href="qpushbutton.html">QPushButton</a>( tr("Quit") , this );
|
---|
| 249 |
|
---|
| 250 | <a name="x792"></a> connect( send, SIGNAL(<a href="qbutton.html#clicked">clicked</a>()), SLOT(sendToServer()) );
|
---|
| 251 | connect( close, SIGNAL(<a href="qbutton.html#clicked">clicked</a>()), SLOT(closeConnection()) );
|
---|
| 252 | connect( quit, SIGNAL(<a href="qbutton.html#clicked">clicked</a>()), qApp, SLOT(<a href="qapplication.html#quit">quit</a>()) );
|
---|
| 253 |
|
---|
| 254 | // create the socket and connect various of its signals
|
---|
| 255 | socket = new <a href="qsocket.html">QSocket</a>( this );
|
---|
| 256 | <a name="x798"></a> connect( socket, SIGNAL(<a href="qsocket.html#connected">connected</a>()),
|
---|
| 257 | SLOT(socketConnected()) );
|
---|
| 258 | <a name="x799"></a> connect( socket, SIGNAL(<a href="qsocket.html#connectionClosed">connectionClosed</a>()),
|
---|
| 259 | SLOT(socketConnectionClosed()) );
|
---|
| 260 | <a name="x803"></a> connect( socket, SIGNAL(<a href="qsocket.html#readyRead">readyRead</a>()),
|
---|
| 261 | SLOT(socketReadyRead()) );
|
---|
| 262 | <a name="x801"></a> connect( socket, SIGNAL(<a href="qsocket.html#error">error</a>(int)),
|
---|
| 263 | SLOT(socketError(int)) );
|
---|
| 264 |
|
---|
| 265 | // connect to the server
|
---|
| 266 | <a name="x805"></a> infoText-><a href="qtextedit.html#append">append</a>( tr("Trying to connect to the server\n") );
|
---|
| 267 | <a name="x797"></a> socket-><a href="qsocket.html#connectToHost">connectToHost</a>( host, port );
|
---|
| 268 | }
|
---|
| 269 |
|
---|
| 270 | ~Client()
|
---|
| 271 | {
|
---|
| 272 | }
|
---|
| 273 |
|
---|
| 274 | private slots:
|
---|
| 275 | void closeConnection()
|
---|
| 276 | {
|
---|
| 277 | <a name="x796"></a> socket-><a href="qsocket.html#close">close</a>();
|
---|
| 278 | <a name="x804"></a> if ( socket-><a href="qsocket.html#state">state</a>() == QSocket::Closing ) {
|
---|
| 279 | // We have a delayed close.
|
---|
| 280 | <a name="x800"></a> connect( socket, SIGNAL(<a href="qsocket.html#delayedCloseFinished">delayedCloseFinished</a>()),
|
---|
| 281 | SLOT(socketClosed()) );
|
---|
| 282 | } else {
|
---|
| 283 | // The socket is closed.
|
---|
| 284 | socketClosed();
|
---|
| 285 | }
|
---|
| 286 | }
|
---|
| 287 |
|
---|
| 288 | void sendToServer()
|
---|
| 289 | {
|
---|
| 290 | // write to the server
|
---|
| 291 | <a href="qtextstream.html">QTextStream</a> os(socket);
|
---|
| 292 | <a name="x794"></a> os << inputText-><a href="qlineedit.html#text">text</a>() << "\n";
|
---|
| 293 | <a name="x793"></a> inputText-><a href="qlineedit.html#setText">setText</a>( "" );
|
---|
| 294 | }
|
---|
| 295 |
|
---|
| 296 | void socketReadyRead()
|
---|
| 297 | {
|
---|
| 298 | // read from the server
|
---|
| 299 | <a name="x795"></a> while ( socket-><a href="qsocket.html#canReadLine">canReadLine</a>() ) {
|
---|
| 300 | <a name="x802"></a> infoText-><a href="qtextedit.html#append">append</a>( socket-><a href="qsocket.html#readLine">readLine</a>() );
|
---|
| 301 | }
|
---|
| 302 | }
|
---|
| 303 |
|
---|
| 304 | void socketConnected()
|
---|
| 305 | {
|
---|
| 306 | infoText-><a href="qtextedit.html#append">append</a>( tr("Connected to server\n") );
|
---|
| 307 | }
|
---|
| 308 |
|
---|
| 309 | void socketConnectionClosed()
|
---|
| 310 | {
|
---|
| 311 | infoText-><a href="qtextedit.html#append">append</a>( tr("Connection closed by the server\n") );
|
---|
| 312 | }
|
---|
| 313 |
|
---|
| 314 | void socketClosed()
|
---|
| 315 | {
|
---|
| 316 | infoText-><a href="qtextedit.html#append">append</a>( tr("Connection closed\n") );
|
---|
| 317 | }
|
---|
| 318 |
|
---|
| 319 | void socketError( int e )
|
---|
| 320 | {
|
---|
| 321 | infoText-><a href="qtextedit.html#append">append</a>( tr("Error number %1 occurred\n").arg(e) );
|
---|
| 322 | }
|
---|
| 323 |
|
---|
| 324 | private:
|
---|
| 325 | <a href="qsocket.html">QSocket</a> *socket;
|
---|
| 326 | <a href="qtextview.html">QTextView</a> *infoText;
|
---|
| 327 | <a href="qlineedit.html">QLineEdit</a> *inputText;
|
---|
| 328 | };
|
---|
| 329 |
|
---|
| 330 |
|
---|
| 331 | int main( int argc, char** argv )
|
---|
| 332 | {
|
---|
| 333 | <a href="qapplication.html">QApplication</a> app( argc, argv );
|
---|
| 334 | Client client( argc<2 ? "localhost" : argv[1], 4242 );
|
---|
| 335 | app.<a href="qapplication.html#setMainWidget">setMainWidget</a>( &client );
|
---|
| 336 | client.<a href="qwidget.html#show">show</a>();
|
---|
| 337 | return app.<a href="qapplication.html#exec">exec</a>();
|
---|
| 338 | }
|
---|
| 339 |
|
---|
| 340 | #include "client.moc"
|
---|
| 341 | </pre>
|
---|
| 342 |
|
---|
| 343 | <p>See also <a href="network-examples.html">Network Examples</a>.
|
---|
| 344 |
|
---|
| 345 | <!-- eof -->
|
---|
| 346 | <p><address><hr><div align=center>
|
---|
| 347 | <table width=100% cellspacing=0 border=0><tr>
|
---|
| 348 | <td>Copyright © 2007
|
---|
| 349 | <a href="troll.html">Trolltech</a><td align=center><a href="trademarks.html">Trademarks</a>
|
---|
| 350 | <td align=right><div align=right>Qt 3.3.8</div>
|
---|
| 351 | </table></div></address></body>
|
---|
| 352 | </html>
|
---|