[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设计模式
- 创建型模式
- 工厂模式
- 单例模式
- 注册器模式
- 工厂模式于策略模式的区别
- 结构型模式
- 适配器模式
- 桥接模式
- 装饰器模式
- 行为型模式
- 观察者模式
- 策略模式
- 高并发设计