(PHP 5 >= 5.1.0, PHP 7, PHP 8)
stream_socket_enable_crypto — Liga ou desliga criptografia em socket já conectado
$stream,$enable,$crypto_method = null,$session_stream = nullLiga ou desliga criptografia no fluxo.
Assim que as configurações de criptografia estiverem estabelecidos, a criptografia pode
ser ligada e desligada dinamicamente passando-se true ou false no parâmetro
enable.
streamO recurso representando o fluxo.
enableLigar/desligar criptografia no fluxo.
crypto_methodConfigura a criptografia no fluxo. Métodos válidos são:
STREAM_CRYPTO_METHOD_SSLv2_CLIENTSTREAM_CRYPTO_METHOD_SSLv3_CLIENTSTREAM_CRYPTO_METHOD_SSLv23_CLIENTSTREAM_CRYPTO_METHOD_ANY_CLIENTSTREAM_CRYPTO_METHOD_TLS_CLIENTSTREAM_CRYPTO_METHOD_TLSv1_0_CLIENTSTREAM_CRYPTO_METHOD_TLSv1_1_CLIENTSTREAM_CRYPTO_METHOD_TLSv1_2_CLIENTSTREAM_CRYPTO_METHOD_TLSv1_3_CLIENT (a partir do PHP 7.4.0)STREAM_CRYPTO_METHOD_SSLv2_SERVERSTREAM_CRYPTO_METHOD_SSLv3_SERVERSTREAM_CRYPTO_METHOD_SSLv23_SERVERSTREAM_CRYPTO_METHOD_ANY_SERVERSTREAM_CRYPTO_METHOD_TLS_SERVERSTREAM_CRYPTO_METHOD_TLSv1_0_SERVERSTREAM_CRYPTO_METHOD_TLSv1_1_SERVERSTREAM_CRYPTO_METHOD_TLSv1_2_SERVERSTREAM_CRYPTO_METHOD_TLSv1_3_SERVER (a partir do PHP 7.4.0)
Se omitido, a opção de contexto crypto_method no
contexto SSL do fluxo será usado.
session_stream
Alimenta o fluxo com as configurações de session_stream.
Retorna true em caso de sucesso, false se a negociação falhar ou
0 se não houver dados suficientes levando a uma nova tentativa
(apenas para sockets em modo de não-bloqueio).
| Versão | Descrição |
|---|---|
| 8.0.0 |
session_stream agora pode ser nulo.
|
Exemplo #1 Exemplo de stream_socket_enable_crypto()
<?php
$fp = stream_socket_client("tcp://myproto.example.com:31337", $errno, $errstr, 30);
if (!$fp) {
die("Não foi possível conectar: $errstr ($errno)");
}
/* Liga criptografia para a fase de autenticação */
stream_socket_enable_crypto($fp, true, STREAM_CRYPTO_METHOD_SSLv23_CLIENT);
fwrite($fp, "USER god\r\n");
fwrite($fp, "PASS secret\r\n");
/* Desliga a criptografia para o restante */
stream_socket_enable_crypto($fp, false);
while ($motd = fgets($fp)) {
echo $motd;
}
fclose($fp);
?>O exemplo acima produzirá algo semelhante a: