2002-04-15 00:12:54 +00:00
|
|
|
<?xml version="1.0" encoding="iso-8859-1"?>
|
2007-12-10 17:06:11 +00:00
|
|
|
<!-- $Revision: 1.27 $ -->
|
2005-09-04 19:39:32 +00:00
|
|
|
<!-- Purpose: remote.other -->
|
|
|
|
<!-- Membership: bundled -->
|
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<reference xml:id="ref.sockets" xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink">
|
2004-02-24 08:46:39 +00:00
|
|
|
<title>Socket Functions</title>
|
2002-04-15 00:12:54 +00:00
|
|
|
<titleabbrev>Sockets</titleabbrev>
|
|
|
|
|
|
|
|
<partintro>
|
2002-07-28 14:04:01 +00:00
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="sockets.intro">
|
2002-07-28 14:04:01 +00:00
|
|
|
&reftitle.intro;
|
|
|
|
<para>
|
|
|
|
The socket extension implements a low-level interface to the socket
|
|
|
|
communication functions based on the popular BSD sockets, providing the
|
|
|
|
possibility to act as a socket server as well as a client.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
For a more generic client-side socket interface, see
|
2003-04-17 21:44:32 +00:00
|
|
|
<function>stream_socket_client</function>,
|
|
|
|
<function>stream_socket_server</function>,
|
|
|
|
<function>fsockopen</function>, and
|
2002-07-28 14:04:01 +00:00
|
|
|
<function>pfsockopen</function>.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
When using these functions, it is important to remember that while
|
|
|
|
many of them have identical names to their C counterparts, they
|
|
|
|
often have different declarations. Please be sure to read the
|
|
|
|
descriptions to avoid confusion.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
Those unfamiliar with socket programming can find a lot
|
|
|
|
of useful material in the appropriate Unix man pages, and there is a great
|
|
|
|
deal of tutorial information on socket programming in C on the web, much
|
|
|
|
of which can be applied, with slight modifications, to socket programming
|
2007-06-20 22:25:43 +00:00
|
|
|
in PHP. The <link xlink:href="&url.socket.faq;">Unix Socket
|
|
|
|
FAQ</link> might be a good start.
|
2002-07-28 14:04:01 +00:00
|
|
|
</para>
|
2006-12-09 13:22:39 +00:00
|
|
|
<note>
|
|
|
|
<para>
|
|
|
|
&pecl.moved-ver;5.3.0.
|
|
|
|
</para>
|
|
|
|
</note>
|
2002-07-28 14:04:01 +00:00
|
|
|
</section>
|
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="sockets.requirements">
|
2002-07-28 14:04:01 +00:00
|
|
|
&reftitle.required;
|
|
|
|
&no.requirement;
|
|
|
|
</section>
|
|
|
|
|
2002-12-02 12:55:46 +00:00
|
|
|
&reference.sockets.configure;
|
2002-07-28 14:04:01 +00:00
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="sockets.configuration">
|
2002-07-28 14:04:01 +00:00
|
|
|
&reftitle.runtime;
|
|
|
|
&no.config;
|
|
|
|
</section>
|
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="sockets.resources">
|
2002-07-28 14:04:01 +00:00
|
|
|
&reftitle.resources;
|
2007-03-03 22:12:01 +00:00
|
|
|
<para>
|
|
|
|
<function>socket_accept</function>,
|
|
|
|
<function>socket_create_listen</function> and
|
|
|
|
<function>socket_create</function> return socket recources.
|
|
|
|
</para>
|
2002-07-28 14:04:01 +00:00
|
|
|
</section>
|
|
|
|
|
|
|
|
&reference.sockets.constants;
|
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="sockets.errors">
|
2002-07-28 14:04:01 +00:00
|
|
|
<title>Socket Errors</title>
|
2002-04-30 21:27:50 +00:00
|
|
|
<para>
|
2004-08-13 01:00:48 +00:00
|
|
|
The socket extension was written to provide a usable interface to the
|
2002-07-28 14:04:01 +00:00
|
|
|
powerful BSD sockets. Care has been taken that the functions work equally
|
|
|
|
well on Win32 and Unix implementations. Almost all of the sockets
|
|
|
|
functions may fail under certain conditions and therefore emit an
|
|
|
|
<constant>E_WARNING</constant> message describing the error. Sometimes this
|
|
|
|
doesn't happen to the desire of the developer. For example the function
|
|
|
|
<function>socket_read</function> may suddenly emit an
|
|
|
|
<constant>E_WARNING</constant> message because the connection broke
|
|
|
|
unexpectedly. It's common to suppress the warning with the
|
|
|
|
<literal>@</literal>-operator and catch the error code within the
|
|
|
|
application with the <function>socket_last_error</function> function. You
|
|
|
|
may call the <function>socket_strerror</function> function with this error
|
|
|
|
code to retrieve a string describing the error. See their description for
|
|
|
|
more information.
|
|
|
|
</para>
|
|
|
|
<note>
|
|
|
|
<para>
|
|
|
|
The <constant>E_WARNING</constant> messages generated by the socket
|
2003-12-19 15:50:07 +00:00
|
|
|
extension are in English though the retrieved error message will appear
|
2002-07-28 14:04:01 +00:00
|
|
|
depending on the current locale (<constant>LC_MESSAGES</constant>):
|
|
|
|
<programlisting role="php">
|
2002-04-30 21:27:50 +00:00
|
|
|
<![CDATA[
|
|
|
|
Warning - socket_bind() unable to bind address [98]: Die Adresse wird bereits verwendet
|
|
|
|
]]>
|
2002-07-28 14:04:01 +00:00
|
|
|
</programlisting>
|
2002-04-15 00:12:54 +00:00
|
|
|
</para>
|
2002-07-28 14:04:01 +00:00
|
|
|
</note>
|
|
|
|
</section>
|
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="sockets.examples">
|
2002-07-28 14:04:01 +00:00
|
|
|
&reftitle.examples;
|
|
|
|
<para>
|
|
|
|
<example>
|
|
|
|
<title>Socket example: Simple TCP/IP server</title>
|
|
|
|
<para>
|
|
|
|
This example shows a simple talkback server. Change the
|
|
|
|
<varname>address</varname> and <varname>port</varname> variables
|
|
|
|
to suit your setup and execute. You may then connect to the
|
|
|
|
server with a command similar to: <command>telnet 192.168.1.53
|
|
|
|
10000</command> (where the address and port match your
|
|
|
|
setup). Anything you type will then be output on the server
|
|
|
|
side, and echoed back to you. To disconnect, enter 'quit'.
|
|
|
|
</para>
|
|
|
|
<programlisting role="php">
|
2002-04-15 00:12:54 +00:00
|
|
|
<![CDATA[
|
|
|
|
#!/usr/local/bin/php -q
|
|
|
|
<?php
|
2003-12-15 16:55:22 +00:00
|
|
|
error_reporting(E_ALL);
|
2002-04-15 00:12:54 +00:00
|
|
|
|
|
|
|
/* Allow the script to hang around waiting for connections. */
|
2003-12-15 16:55:22 +00:00
|
|
|
set_time_limit(0);
|
2002-04-15 00:12:54 +00:00
|
|
|
|
|
|
|
/* Turn on implicit output flushing so we see what we're getting
|
|
|
|
* as it comes in. */
|
2003-12-15 16:55:22 +00:00
|
|
|
ob_implicit_flush();
|
2002-04-15 00:12:54 +00:00
|
|
|
|
|
|
|
$address = '192.168.1.53';
|
|
|
|
$port = 10000;
|
|
|
|
|
2007-01-16 22:21:23 +00:00
|
|
|
if (($sock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP)) === false) {
|
|
|
|
echo "socket_create() failed: reason: " . socket_strerror(socket_last_error()) . "\n";
|
2002-04-15 00:12:54 +00:00
|
|
|
}
|
|
|
|
|
2007-01-16 22:21:23 +00:00
|
|
|
if (socket_bind($sock, $address, $port) === false) {
|
|
|
|
echo "socket_bind() failed: reason: " . socket_strerror(socket_last_error($sock)) . "\n";
|
2002-04-15 00:12:54 +00:00
|
|
|
}
|
|
|
|
|
2007-01-16 22:21:23 +00:00
|
|
|
if (socket_listen($sock, 5) === false) {
|
|
|
|
echo "socket_listen() failed: reason: " . socket_strerror(socket_last_error($sock)) . "\n";
|
2002-04-15 00:12:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
do {
|
2007-02-15 20:13:39 +00:00
|
|
|
if (($msgsock = socket_accept($sock)) === false) {
|
2007-01-16 22:21:23 +00:00
|
|
|
echo "socket_accept() failed: reason: " . socket_strerror(socket_last_error($sock)) . "\n";
|
2002-04-15 00:12:54 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
/* Send instructions. */
|
|
|
|
$msg = "\nWelcome to the PHP Test Server. \n" .
|
|
|
|
"To quit, type 'quit'. To shut down the server type 'shutdown'.\n";
|
|
|
|
socket_write($msgsock, $msg, strlen($msg));
|
|
|
|
|
|
|
|
do {
|
2003-12-15 16:55:22 +00:00
|
|
|
if (false === ($buf = socket_read($msgsock, 2048, PHP_NORMAL_READ))) {
|
2007-01-16 22:21:23 +00:00
|
|
|
echo "socket_read() failed: reason: " . socket_strerror(socket_last_error($msgsock)) . "\n";
|
2002-04-15 00:12:54 +00:00
|
|
|
break 2;
|
|
|
|
}
|
2003-12-15 16:55:22 +00:00
|
|
|
if (!$buf = trim($buf)) {
|
2002-04-15 00:12:54 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if ($buf == 'quit') {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if ($buf == 'shutdown') {
|
2003-12-15 16:55:22 +00:00
|
|
|
socket_close($msgsock);
|
2002-04-15 00:12:54 +00:00
|
|
|
break 2;
|
|
|
|
}
|
|
|
|
$talkback = "PHP: You said '$buf'.\n";
|
2003-12-15 16:55:22 +00:00
|
|
|
socket_write($msgsock, $talkback, strlen($talkback));
|
2002-04-15 00:12:54 +00:00
|
|
|
echo "$buf\n";
|
|
|
|
} while (true);
|
2003-12-15 16:55:22 +00:00
|
|
|
socket_close($msgsock);
|
2002-04-15 00:12:54 +00:00
|
|
|
} while (true);
|
|
|
|
|
2003-12-15 16:55:22 +00:00
|
|
|
socket_close($sock);
|
2002-04-15 00:12:54 +00:00
|
|
|
?>
|
|
|
|
]]>
|
2002-07-28 14:04:01 +00:00
|
|
|
</programlisting>
|
|
|
|
</example>
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
<example>
|
|
|
|
<title>Socket example: Simple TCP/IP client</title>
|
|
|
|
<para>
|
|
|
|
This example shows a simple, one-shot HTTP client. It simply
|
|
|
|
connects to a page, submits a HEAD request, echoes the reply,
|
|
|
|
and exits.
|
|
|
|
</para>
|
2003-08-16 18:59:12 +00:00
|
|
|
<programlisting role="php">
|
2002-04-15 00:12:54 +00:00
|
|
|
<![CDATA[
|
|
|
|
<?php
|
2003-12-15 16:55:22 +00:00
|
|
|
error_reporting(E_ALL);
|
2002-04-15 00:12:54 +00:00
|
|
|
|
|
|
|
echo "<h2>TCP/IP Connection</h2>\n";
|
|
|
|
|
|
|
|
/* Get the port for the WWW service. */
|
2003-12-15 16:55:22 +00:00
|
|
|
$service_port = getservbyname('www', 'tcp');
|
2002-04-15 00:12:54 +00:00
|
|
|
|
|
|
|
/* Get the IP address for the target host. */
|
2003-12-15 16:55:22 +00:00
|
|
|
$address = gethostbyname('www.example.com');
|
2002-04-15 00:12:54 +00:00
|
|
|
|
|
|
|
/* Create a TCP/IP socket. */
|
2003-12-15 19:41:43 +00:00
|
|
|
$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);
|
2007-01-16 22:21:23 +00:00
|
|
|
if ($socket === false) {
|
|
|
|
echo "socket_create() failed: reason: " . socket_strerror(socket_last_error()) . "\n";
|
2002-04-15 00:12:54 +00:00
|
|
|
} else {
|
|
|
|
echo "OK.\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
echo "Attempting to connect to '$address' on port '$service_port'...";
|
2003-12-15 16:55:22 +00:00
|
|
|
$result = socket_connect($socket, $address, $service_port);
|
2007-01-16 22:21:23 +00:00
|
|
|
if ($result === false) {
|
|
|
|
echo "socket_connect() failed.\nReason: ($result) " . socket_strerror(socket_last_error($socket)) . "\n";
|
2002-04-15 00:12:54 +00:00
|
|
|
} else {
|
|
|
|
echo "OK.\n";
|
|
|
|
}
|
|
|
|
|
2003-12-10 15:28:18 +00:00
|
|
|
$in = "HEAD / HTTP/1.1\r\n";
|
2003-12-11 14:21:06 +00:00
|
|
|
$in .= "Host: www.example.com\r\n";
|
|
|
|
$in .= "Connection: Close\r\n\r\n";
|
2002-04-15 00:12:54 +00:00
|
|
|
$out = '';
|
|
|
|
|
|
|
|
echo "Sending HTTP HEAD request...";
|
2003-12-15 16:55:22 +00:00
|
|
|
socket_write($socket, $in, strlen($in));
|
2002-04-15 00:12:54 +00:00
|
|
|
echo "OK.\n";
|
|
|
|
|
|
|
|
echo "Reading response:\n\n";
|
2003-12-15 16:55:22 +00:00
|
|
|
while ($out = socket_read($socket, 2048)) {
|
2002-04-15 00:12:54 +00:00
|
|
|
echo $out;
|
|
|
|
}
|
|
|
|
|
|
|
|
echo "Closing socket...";
|
2003-12-15 16:55:22 +00:00
|
|
|
socket_close($socket);
|
2002-04-15 00:12:54 +00:00
|
|
|
echo "OK.\n\n";
|
|
|
|
?>
|
|
|
|
]]>
|
|
|
|
</programlisting>
|
|
|
|
</example>
|
|
|
|
</para>
|
2002-07-28 14:04:01 +00:00
|
|
|
</section>
|
2002-04-15 00:12:54 +00:00
|
|
|
</partintro>
|
|
|
|
|
2007-12-10 17:06:11 +00:00
|
|
|
&reference.sockets.entities.functions;
|
2002-04-15 00:12:54 +00:00
|
|
|
|
|
|
|
</reference>
|
|
|
|
<!-- Keep this comment at the end of the file
|
|
|
|
Local variables:
|
|
|
|
mode: sgml
|
|
|
|
sgml-omittag:t
|
|
|
|
sgml-shorttag:t
|
|
|
|
sgml-minimize-attributes:nil
|
|
|
|
sgml-always-quote-attributes:t
|
|
|
|
sgml-indent-step:1
|
|
|
|
sgml-indent-data:t
|
|
|
|
indent-tabs-mode:nil
|
|
|
|
sgml-parent-document:nil
|
|
|
|
sgml-default-dtd-file:"../../../manual.ced"
|
|
|
|
sgml-exposed-tags:nil
|
|
|
|
sgml-local-catalogs:nil
|
|
|
|
sgml-local-ecat-files:nil
|
|
|
|
End:
|
|
|
|
vim600: syn=xml fen fdm=syntax fdl=2 si
|
|
|
|
vim: et tw=78 syn=sgml
|
|
|
|
vi: ts=1 sw=1
|
|
|
|
-->
|
|
|
|
|