Linux and UNIX Man Pages

Linux & Unix Commands - Search Man Pages

stream_socket_shutdown(3) [php man page]

STREAM_SOCKET_SHUTDOWN(3)						 1						 STREAM_SOCKET_SHUTDOWN(3)

stream_socket_shutdown - Shutdown a full-duplex connection

SYNOPSIS
bool stream_socket_shutdown (resource $stream, int $how) DESCRIPTION
Shutdowns (partially or not) a full-duplex connection. PARAMETERS
o $stream - An open stream (opened with stream_socket_client(3), for example) o $how - One of the following constants: STREAM_SHUT_RD (disable further receptions), STREAM_SHUT_WR (disable further transmissions) or STREAM_SHUT_RDWR (disable further receptions and transmissions). RETURN VALUES
Returns TRUE on success or FALSE on failure. EXAMPLES
Example #1 A stream_socket_shutdown(3) example <?php $server = stream_socket_server('tcp://127.0.0.1:1337'); $client = stream_socket_client('tcp://127.0.0.1:1337'); var_dump(fputs($client, "hello")); stream_socket_shutdown($client, STREAM_SHUT_WR); var_dump(fputs($client, "hello")); // doesn't work now ?> The above example will output something similar to: int(5) Notice: fputs(): send of 5 bytes failed with errno=32 Broken pipe in test.php on line 9 int(0) SEE ALSO
fclose(3). PHP Documentation Group STREAM_SOCKET_SHUTDOWN(3)

Check Out this Related Man Page

STREAM_SOCKET_ENABLE_CRYPTO(3)						 1					    STREAM_SOCKET_ENABLE_CRYPTO(3)

stream_socket_enable_crypto - Turns encryption on/off on an already connected socket

SYNOPSIS
mixed stream_socket_enable_crypto (resource $stream, bool $enable, [int $crypto_type], [resource $session_stream]) DESCRIPTION
Enable or disable encryption on the stream. Once the crypto settings are established, cryptography can be turned on and off dynamically by passing TRUE or FALSE in the $enable param- eter. PARAMETERS
o $stream - The stream resource. o $enable - Enable/disable cryptography on the stream. o $crypto_type - Setup encryption on the stream. Valid methods are o STREAM_CRYPTO_METHOD_SSLv2_CLIENT o STREAM_CRYPTO_METHOD_SSLv3_CLIENT o STREAM_CRYPTO_METHOD_SSLv23_CLIENT o STREAM_CRYPTO_METHOD_TLS_CLIENT o STREAM_CRYPTO_METHOD_SSLv2_SERVER o STREAM_CRYPTO_METHOD_SSLv3_SERVER o STREAM_CRYPTO_METHOD_SSLv23_SERVER o STREAM_CRYPTO_METHOD_TLS_SERVER If omitted, the $crypto_type context option on the stream's SSL context will be used instead. o $session_stream - Seed the stream with settings from $session_stream. RETURN VALUES
Returns TRUE on success, FALSE if negotiation has failed or 0 if there isn't enough data and you should try again (only for non-blocking sockets). CHANGELOG
+--------+------------------------------------+ |Version | | | | | | | Description | | | | +--------+------------------------------------+ | 5.6.0 | | | | | | | The $crypto_type is now optional. | | | | +--------+------------------------------------+ EXAMPLES
Example #1 stream_socket_enable_crypto(3) example <?php $fp = stream_socket_client("tcp://myproto.example.com:31337", $errno, $errstr, 30); if (!$fp) { die("Unable to connect: $errstr ($errno)"); } /* Turn on encryption for login phase */ stream_socket_enable_crypto($fp, true, STREAM_CRYPTO_METHOD_SSLv23_CLIENT); fwrite($fp, "USER god "); fwrite($fp, "PASS secret "); /* Turn off encryption for the rest */ stream_socket_enable_crypto($fp, false); while ($motd = fgets($fp)) { echo $motd; } fclose($fp); ?> The above example will output something similar to: SEE ALSO
"OpenSSL Functions", "List of Supported Socket Transports". PHP Documentation Group STREAM_SOCKET_ENABLE_CRYPTO(3)
Man Page