## 客戶端測試 (JavaScript)
**1. 啟動 mix-websocketd 服務**
~~~
php mix-websocketd start -c ../applications/websocket/config/websocketd.php
~~~
**2. 將下面代碼另存為一個 HTML 文件,在 Chrome 調試模式的 Console 窗口中調試**
~~~
<html>
<head>
<title>WebSocket</title>
</head>
<body>
<script>
var webSocket = function () {
ws = new WebSocket("ws://www.test.com/websocket");
ws.onopen = function() {
console.log("連接成功");
};
ws.onmessage = function(e) {
console.log("收到服務端的消息:" + e.data);
};
ws.onclose = function() {
console.log("連接關閉");
};
};
webSocket();
</script>
</body>
</html>
~~~
**4. 開始測試**
>[success] 加入房間范例代碼測試。
在 Console 窗口中輸入:
~~~
ws.send('{"method":"join.room","params":{"roomid":1010},"id":1}');
~~~
會收到以下響應:
~~~
收到服務端的文本消息:{"result":{"message":" 加入 1010 房間."},"id":1}
~~~
>[success] 發送消息給用戶范例代碼測試。
在 Console 窗口中輸入:
~~~
ws.send('{"method":"message.emit","params":{"message":"hidfsdfsdfasdfsdfasdfasdfasdfasdfsdf"},"id":2}');
~~~
會收到以下響應:
~~~
收到服務端的文本消息:{"result":{"message":"hidfsdfsdfasdfsdfasdfasdfasdfasdfsdf"},"id":2}
~~~
## 客戶端測試 (Swoole)
Swoole 本身提供了 [協程版本的客戶端](https://wiki.swoole.com/wiki/page/868.html),因為高度封裝,所以 mix 就不封裝了,用戶可直接在 mix 中使用,下面是一個 原生 DEMO。
>[danger] 當在 mix 中使用下面代碼時,需將 go 修改為 xgo
將下面代碼保存為 `client.php`
~~~
go(function () {
$cli = new \Swoole\Coroutine\http\Client("127.0.0.1", 9502);
$ret = $cli->upgrade("/websocket");
if ($ret) {
$cli->push('{"method":"join.room","params":{"roomid":1010},"id":1}');
while (true) {
$data = $cli->recv();
if ($data === false) {
echo "disconnect" . PHP_EOL;
break;
}
var_dump($data);
}
}
});
~~~
**1. 啟動 mix-websocketd 服務**
~~~
php mix-websocketd start -c ../applications/websocket/config/websocketd.php
~~~
**2. 執行 `client.php`**
~~~
php client.php
~~~
接收到加入成功的消息:
~~~
[root@localhost data]# php client.php
object(Swoole\WebSocket\Frame)#3 (4) {
["fd"]=>
int(0)
["data"]=>
string(58) "{"result":{"message":"小明 加入 1010 房間."},"id":1}"
["opcode"]=>
int(1)
["finish"]=>
bool(true)
}
~~~
- 歡迎使用 MixPHP
- 安裝說明
- 全量安裝
- Phar 命令行
- 入門須知
- 增改應用
- 命名空間
- 自動加載
- 入口文件
- 配置文件
- 服務開發
- 核心基礎
- Bean
- Component
- Application
- 命令行
- 簡介
- 命令行開發常識
- 命令行開發
- 創建命令
- 命令參數
- 打印與顏色
- 控制臺程序
- 守護程序
- HTTP 服務
- 簡介
- 服務器
- 路由
- 請求
- 響應
- 控制器
- 視圖
- Auth
- Session
- 文件上傳
- 其他組件
- 分頁
- 驗證碼
- 圖片處理
- 客戶端
- GuzzleHttp
- 雜項
- Apache/PHP-FPM部署
- 調試與錯誤
- 安全建議
- WebSocket 服務
- 簡介
- 服務器
- 注冊器
- 連接
- 客戶端
- 測試
- 雜項
- nginx代理
- 60s無消息斷線
- TCP 服務
- 簡介
- 服務器
- 客戶端
- 測試
- UDP 服務
- 簡介
- 服務器
- 客戶端
- 測試
- 協程
- 簡介
- 開啟協程
- PHP Stream Hook
- xgo + Channel
- WaitGroup + xdefer
- 連接池
- 協程池
- 定時器
- 公共組件
- 中間件
- 驗證器
- 驗證器定義
- 驗證規則
- 靜態調用
- 模型
- 日志
- 緩存
- 數據庫
- Database
- QueryBuilder
- PDOConnection
- Persistent\PDOConnection
- Coroutine\PDOConnection
- MasterSlave\PDOConnection
- ExecuteListener
- Redis
- RedisConnection
- Persistent\RedisConnection
- Coroutine\RedisConnection
- ExecuteListener
- 常見問題
- 同一臺服務器部署多個服務
- 連接多個數據庫
- 如何設置跨域
- form-data 上傳文件失敗
- 開發工具
- 版本更新
- 不兼容改動
- 升級指南
- 文檔歷史