您的位置:首页 > 技术中心 > PHP教程 >

php生成token的方法

时间:2020-09-29 09:41

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_idvarchar(20)客户端ID
client_secretvarchar(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

本类排行

今日推荐

热门手游