WebSocket(ws)은 html5에 추가된 새로운 통신 프로토콜입니다. 현재 널리 사용되는 브라우저(예: Chrome, Safrie, Firefox, Opera, IE 등)가 이 프로토콜을 지원합니다. 이 프로토콜에 대한 가장 빠른 지원은 다음과 같습니다. chrome12부터 지원되는 chrome입니다. 프로토콜 초안이 계속 변경됨에 따라 각 브라우저의 프로토콜 구현도 지속적으로 업데이트됩니다. (추천 학습: swoole 비디오 튜토리얼)
swoole 1.7.9에는 내장 WebSocket 서버 지원이 추가되었으며 몇 줄의 PHP 코드로 비동기 비차단 다중 프로세스 WebSocket 서버를 작성할 수 있습니다.
$server = new Swoole\WebSocket\Server("0.0.0.0", 9501); $server->on('open', function (Swoole\WebSocket\Server $server, $request) { echo "server: handshake success with fd{$request->fd}\n"; }); $server->on('message', function (Swoole\WebSocket\Server $server, $frame) { echo "receive from {$frame->fd}:{$frame->data},opcode:{$frame->opcode},fin:{$frame->finish}\n"; $server->push($frame->fd, "this is server"); }); $server->on('close', function ($ser, $fd) { echo "client {$fd} closed\n"; }); $server->start();
WebSocket 서버는 SwooleServer 및 SwooleHttpServer 기본 클래스의 콜백 함수를 수신하는 것 외에도 3개의 추가 콜백 함수 설정을 추가합니다. 그 중:
onMessage 콜백 함수는 필수입니다. onOpen 및 onHandShake 콜백 함수는 선택 사항입니다.WebSocketServer는 Server의 하위 클래스이므로 Server의 모든 메서드를 호출할 수 있습니다.
WebSocket 서버는 WebSocketServer::push 메서드를 사용하여 클라이언트에 데이터를 보내야 한다는 점에 유의해야 합니다. 이 메서드는 WebSocket 프로토콜을 패키징합니다. Server::send 메소드는 원래의 TCP 전송 인터페이스입니다. WebSocketServer::disconnect 메소드는 서버에서 WebSocket 연결을 적극적으로 닫을 수 있습니다. 상태 코드를 지정할 수 있습니다(WebSocket 프로토콜에 따라 사용 가능한 상태 코드는 10진수이며 값은 1000 또는 4000-4999일 수 있음). 닫는 이유. (UTF-8 인코딩을 사용하여 바이트 길이가 125를 초과하지 않는 문자열) 지정하지 않으면 상태 코드는 1000이고 종료 이유는 비어 있습니다위 내용은 swoole로 ws를 여는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!