php生成token的方法:首先获取GET参数值;然后根据客户端传过来的“client_id”查询数据库,并获取对应的“client_secret”;最后通过md5方法重新生成一份“api_token”即可。
推荐:《PHP视频教程》
接口特点汇总:
1、因为是非开放性的,所以所有的接口都是封闭的,只对公司内部的产品有效;
2、因为是非开放性的,所以OAuth那套协议是行不通的,因为没有中间用户的授权过程;
3、有点接口需要用户登录才能访问;
4、有点接口不需要用户登录就可访问;
针对以上特点,移动端与服务端的通信就需要2把钥匙,即2个token。
第一个token是针对接口的(api_token);
第二个token是针对用户的(user_token);
先说第一个token(api_token)
它的职责是保持接口访问的隐蔽性和有效性,保证接口只能给自家人用,怎么做到?参考思路如下:
现在的接口基本是mvc模式,URL基本是restful风格,URL大体格式如下:
http://blog.snsgou.com/模块名/控制器名/方法名?参数名1=参数值1&参数名2=参数值2&参数名3=参数值3
接口token生成规则参考如下:
api_token = md5 ('模块名' + '控制器名' + '方法名' + '2013-12-18' + '加密密钥') = 770fed4ca2aabd20ae9a5dd774711de2
其中的
1、 '2013-12-18' 为当天时间,
2、'加密密钥' 为私有的加密密钥,手机端需要在服务端注册一个“接口使用者”账号后,系统会分配一个账号及密码,数据表设计参考如下:
字段名 | 字段类型 | 注释 |
client_id | varchar(20) | 客户端ID |
client_secret | varchar(20) | 客户端(加密)密钥 |
(注:只列出了核心字段,其它的再扩展吧!!!)
服务端接口校验,PHP实现流程如下:
01 | <?php |
02 | // 1、获取 GET参数 值 |
03 | $module = $_GET [ 'mod' ]; |
04 | $controller = $_GET [ 'ctl' ] |
05 | $action = $_GET [ 'act' ]; |
06 | $client_id = $_GET [ 'client_id' ]; |
07 | $api_token = $_GET [ '' api_token]; |
08 |
09 | // 2、根据客户端传过来的 client_id ,查询数据库,获取对应的 client_secret |
10 | $client_secret = getClientSecretById( $client_id ); |
11 |
|