# HttpInput
獲取Http訪問的輸入數據。
Controller通過$this->http_input獲取。
## 獲取原生Swoole Request對象
也許你習慣了使用原生的swoole request對象,可以使用以下方式獲取:
```php
public function index(){
$swoole_http_request = $this->http_input->request;
//TODO 你可以自己獲取并且解析原生swoole_http_request值
}
```
## API
* postGet
優先先從post中取值,若沒有再從get中取值;如果post與get中有相同的字段名,則以post值為準。如果都不存在則返回空字符串
*xss_clean:是否使用xss清理*
* post
從post中取值,若不存在則返回空字符串
*xss_clean:是否使用xss清理*
* get
從get中取值,若不存在則返回空字符串
*xss_clean:是否使用xss清理*
* getPost
優先從get中取值,若沒有再從post中取值;如果post與get中有相同的字段名,則以get值為準。如果都不存在則返回空字符串
*xss_clean:是否使用xss清理*
* getAllPostGet
獲取所有的post和get,合并返回一個數組,若get和post中有相同字段post會覆蓋get的值。
* getAllHeader
獲取Http請求的頭部所有信息。類型為數組,**所有key均為小寫**。(實際上是返回原生的swoole http請求頭)
* getRawContent
獲取原始的POST包體,用于非application/x-www-form-urlencoded格式的Http POST請求。(等同于原生swoole http rawContent), 此函數等同于PHP的fopen('php://input')。
* cookie
獲取cookie數據
* getRequestHeader
獲取頭信息
* server
獲取server信息,注意字段全是小寫:
```
[request_method] => GET
[request_uri] => /
[path_info] => /
[request_time] => 1484215271
[request_time_float] => 1484215271.2045
[server_port] => 8081
[remote_port] => 56738
[remote_addr] => 127.0.0.1
[server_protocol] => HTTP/1.1
[server_software] => swoole-http-server
```
* getRequestMethod
獲取請求的方式
* getRequestUri
獲取請求的Uri
用此函數獲取的Uri與server信息中的request_uri略有不同,getRequestUri會判斷server中是否存在query_string,若存在則拼接返回一個完整的Uri
* getPathInfo
獲取請求的Path getPathInfo 函數獲取的信息與server中的path_info一致。
- 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