STREAM_SOCKET_SHUTDOWN(3) 1 STREAM_SOCKET_SHUTDOWN(3)stream_socket_shutdown - Shutdown a full-duplex connectionSYNOPSIS
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)