# WebSocket相關
介紹WebSocket獨有的方法
## opcode
在ports.php配置中
```
'opcode' => PortManager::WEBSOCKET_OPCODE_TEXT,
```
* PortManager::WEBSOCKET_OPCODE_TEXT:文本模式
* PortManager::WEBSOCKET_OPCODE_BINARY:二進制模式
## onWebSocketHandCheck
AppServer中onWebSocketHandCheck方法。
```
/**
* 可以在這驗證WebSocket連接,return true代表可以握手,false代表拒絕
* @param HttpInput $httpInput
* @return bool
*/
public function onWebSocketHandCheck(HttpInput $httpInput)
{
return true;
}
```
可以在這驗證WebSocket連接,return true代表可以握手,false代表拒絕。需要設置setCustomHandshake為true,否則不生效。
通過$httpInput可以獲取到創建連接時的URL地址,可以通過攜帶的token或者其他字段進行權限驗證,返回true代表驗證通過可以握手。
## setCustomHandshake
AppServer中setCustomHandshake方法。
是否自定義握手,默認是false,將采用默認的握手規則,如果需要自定義則需要在AppServer的__construct方法中賦值為true。
## onSwooleWSHandShake
AppServer中onSwooleWSHandShake方法。
自定義握手規則,可以通過重寫此方法實現,setCustomHandshake需要設置為true。
## 發送消息
和TCP共用API
## 搭配默認封裝器和路由器
推薦ws的默認封裝器為NonJsonPack,他是以json作為數據的封裝,默認的路由器為NormalRoute,他需求的格式如下。
```
stdClass{
controller_name=>"",
method_name=>"",
path=>"",
params=>""
}
```
其中controller_name和method_name是必須的字段。stdClass中可以包含其他命名字段,所有數據作為整體傳遞給Controller。
結合NonJsonPack那么客戶端發出的基礎數據應該為下面格式的json文本
```
{"controller_name":"*","method_name":"*"}
```
- SD3.X簡介
- 捐贈SD項目
- VIP服務
- 基礎篇
- 搭建環境
- 使用Composer安裝/更新SD框架
- 啟動命令
- 開發注意事項
- 框架配置
- 配置文件夾
- server.php
- ports.php
- business.php
- mysql.php
- redis.php
- timerTask.php
- log.php
- consul.php
- catCache.php
- client.php
- 自定義配置
- 框架入口
- MVC架構
- 加載器-Loader
- 控制器-Controller
- 模型-Model
- 視圖-View
- 同步任務-Task
- 封裝器
- Swoole編程指南-EOF協議
- Swoole編程指南-固定包頭協議
- 封裝器-Pack
- 路由器
- TCP相關
- 綁定UID
- Send系列
- Sub/Pub
- 獲取服務器信息
- Http相關
- HttpInput
- HttpOutput
- 默認路由規則
- WebSocket相關
- 使用SSL
- 公共函數
- 進階篇
- 內核優化
- 封裝器路由器原理剖析
- 對象池
- 上下文-Context
- 中間件
- 進程管理
- 創建自定義進程
- 進程間RPC
- 自定義進程如何使用連接池
- 異步連接池
- Redis
- Mysql
- Mqtt
- HttpClient
- Client
- AMQP
- RPC
- 日志工具-GrayLog
- 微服務-Consul
- Consul基礎
- 搭建Consul服務器
- SD中Consul配置
- 微服務
- 選舉-Leader
- Consul動態配置定時任務
- 熔斷與降級
- 集群-Cluster
- 高速緩存-CatCache
- 萬物-Actor
- Actor原型
- Actor的創建
- Actor間的通訊
- 消息派發-EventDispatcher
- 延遲隊列-TimerCallBack
- 協程
- 訂閱與發布
- MQTT簡易服務器
- AMQP異步任務調度
- 自定義命令-Console
- 調試工具Channel
- 特別注意事項
- 日常問題總結
- 實踐案例
- 物聯網自定義協議
- Actor在游戲的應用
- Mongodb以及一些同步擴展的使用
- 自定義進程使用MQTT客戶端
- 開發者工具
- SDHelper