作为wss客户端

有时候需要让workerman作为客户端以wss协议去连接某个服务端,并与之交互。
以下是示例。

1、workerman作为wss客户端(不需要本地证书)

  1. <?php
  2. use Workerman\Worker;
  3. use Workerman\Connection\AsyncTcpConnection;
  4. require_once __DIR__ . '/../Workerman/Autoloader.php';
  5. $worker = new Worker();
  6. $worker->onWorkerStart = function($worker){
  7. // ssl需要访问443端口
  8. $con = new AsyncTcpConnection('ws://echo.websocket.org:443');
  9. // 设置以ssl加密方式访问
  10. $con->transport = 'ssl';
  11. $con->onConnect = function($con) {
  12. $con->send('hello');
  13. };
  14. $con->onMessage = function($con, $data) {
  15. echo $data;
  16. };
  17. $con->connect();
  18. };
  19. Worker::runAll();

2、workerman作为wss客户端(需要本地证书)

  1. <?php
  2. use Workerman\Worker;
  3. use Workerman\Connection\AsyncTcpConnection;
  4. require_once __DIR__ . '/../Workerman/Autoloader.php';
  5. $worker = new Worker();
  6. $worker->onWorkerStart = function($worker){
  7. // 设置访问对方主机的本地ip及端口以及ssl证书
  8. $context_option = array(
  9. 'socket' => array(
  10. // ip必须是本机网卡ip,并且能访问对方主机,否则无效
  11. 'bindto' => '114.215.84.87:2333',
  12. ),
  13. // ssl选项,参考http://php.net/manual/zh/context.ssl.php
  14. 'ssl' => array(
  15. // 本地证书路径。 必须是 PEM 格式,并且包含本地的证书及私钥。
  16. 'local_cert' => '/your/path/to/pemfile',
  17. // local_cert 文件的密码。
  18. 'passphrase' => 'your_pem_passphrase',
  19. // 是否允许自签名证书。
  20. 'allow_self_signed' => true,
  21. // 是否需要验证 SSL 证书。
  22. 'verify_peer' => false
  23. )
  24. );
  25. // ssl需要访问443端口
  26. $con = new AsyncTcpConnection('ws://echo.websocket.org:443', $context_option);
  27. // 设置以ssl加密方式访问
  28. $con->transport = 'ssl';
  29. $con->onConnect = function($con) {
  30. $con->send('hello');
  31. };
  32. $con->onMessage = function($con, $data) {
  33. echo $data;
  34. };
  35. $con->connect();
  36. };
  37. Worker::runAll();