[TOC]
## 1. 接口使用HTTPS
## 2. Header 中帶必要參數
> 所有的接口,header帶上以下參數
| 參數 | 說明 | 例子 |
| --- | --- | --- |
| app_type | 客戶端類型(1iOS /2安卓) | 安卓 |
| app_device | 手機設備ID | 869118048312573 |
| app_model | 手機型號 | OPPO R11t |
| app_version | APP應用版本號 | 1.0.1 |
| push_device_token | 極光推送設備ID | 100d8559092d402c5c4
| sign | 簽名 | 使用user_token+timeline進行AES-256-CBC加密,防偽造/篡改/防重發(服務端校驗) |
> 1. 接口中 user_token和timeline都不傳遞,都加入到sign中,服務端根據sign獲取到對應的user_token和timeline,并進行校驗;
> 2. user_token:用戶唯一訪問口令,選填選項,因為有些接口不一定要求用戶權限校驗
> 3. timestamp:訪問時間戳,防止接口不斷重發模擬或者ddos,服務端設置該接口的有效使用期為1分鐘,過期作廢
### 4. timestamp 服務端與客戶端同步問題
> 1. 方法1
> 在客戶端啟動時請求的init接口,獲取到服務端時間,進行時間差異計算,這個時候客戶端請求之后的api時,通過差異時間獲取最新時間
> 2. 方法2
> 客戶端如果時間有誤時,可以返回錯誤的同時再返回一個服務器的當前時間,客戶端接收到該錯誤后再請求上一個接口(客戶端需控制不斷錯誤請求的次數)
> 最好的方式是兩者結合
- 重點知識預覽
- 理解面向對象
- 魔術變量
- 魔法方法
- 面試題基礎篇
- PSR標準
- class (單繼承)
- trait (多繼承)
- 匿名函數
- 日期處理
- 文件處理
- 字符串處理
- BC Math
- 數組處理
- HTTP的各個狀態
- PHP環境變量
- session & cookie
- composer
- 變量的類型轉換和判斷類型方法
- PHP的錯誤和異常處理
- PHP的ob緩沖區
- PHP內存調試
- pcntl多進程
- PHP yield (生成器):節約內存
- Nginx負載均衡
- 同一臺服務器如何測試負載均衡
- 安全方面
- HTTPS實現
- PHP性能分析(xhprof)
- 高并發雪崩解決方法
- 接口加密設計(安全性)
- 數據庫(重要數據操作)日志記錄規范
- APP發版操作
- 緩存使用
- Memcache
- MYSQL緩存
- Redis
- 安裝與使用
- redis過期策略和內存淘汰機制
- Redis分布式鎖
- Redis雪崩、穿透、擊穿問題
- redis主從
- redis哨兵
- opcache
- 消息隊列
- Redis消息隊列
- Beanstalkd
- 數據庫匯總
- MYSQL哪些情況下會忽略索引
- MYSQL常用命令
- SQL高級運用
- MYSQL分布式集群使用
- 主從復制
- 同一臺服務器如何測試主從同步
- MYSQL索引類型
- MYSQL分區
- 鎖機制
- 事務隔離級別(臟讀、幻讀、不可重復讀)
- 分布式事務
- MYSQL性能優化
- swoole
- 安裝以及升級
- swoole進程初識
- TCP相關教程
- TCP數據傳輸DEMO(含同步、異步、長連接)
- Server異步投遞task任務
- TCP粘包問題
- websocket相關教程
- websocket初體驗DEMO
- websocket核心功能(心跳檢測、用戶校驗、重連機制)
- websocket用戶之間通信DEMO
- 定時器的使用
- 常駐內存以及如何避免內存泄漏
- max_request使用實例
- 守護進程、信號和平滑重啟
- 全文檢索工具
- MYSQL全文索引
- ElasticSearch全文檢索
- ES基礎知識
- Mapping及增刪改查
- DSL查詢語法
- 搜索建議 (completion)
- mysql轉dsl工具
- ES的安裝與PHP測試
- kibana可視化工具
- ELK日志管理系統
- PHP設計模式
- 創建型模式
- 工廠模式
- 單例模式
- 注冊器模式
- 工廠模式于策略模式的區別
- 結構型模式
- 適配器模式
- 橋接模式
- 裝飾器模式
- 行為型模式
- 觀察者模式
- 策略模式
- 高并發設計