我的编程空间,编程开发者的网络收藏夹
学习永远不晚

PHP中token如何生成

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

PHP中token如何生成

这篇文章主要为大家展示了“PHP中token如何生成”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“PHP中token如何生成”这篇文章吧。

php token的生成

接口特点汇总:

因为是非开放性的,所以所有的接口都是封闭的,只对公司内部的产品有效;

因为是非开放性的,所以OAuth那套协议是行不通的,因为没有中间用户的授权过程;

有点接口需要用户登录才能访问;

有点接口不需要用户登录就可访问;

针对以上特点,移动端与服务端的通信就需要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

其中的

'2013-12-18' 为当天时间,

'加密密钥' 为私有的加密密钥,手机端需要在服务端注册一个“接口使用者”账号后,系统会分配一个账号及密码,数据表设计参考如下:

字段名字段类型注释
client_idvarchar(20)客户端ID
client_secretvarchar(20)客户端(加密)密钥

服务端接口校验,PHP实现流程如下:

<?php// 1、获取 GET参数 值$module = $_GET['mod'];$controller = $_GET['ctl']$action = $_GET['act'];$client_id = $_GET['client_id'];$api_token = $_GET[''api_token];// 2、根据客户端传过来的 client_id ,查询数据库,获取对应的 client_secret$client_secret = getClientSecretById($client_id);// 3、服务端重新生成一份 api_token$api_token_server = md5($module . $controller . $action .  date('Y-m-d', time()) .  $client_secret);// 4、客户端传过来的 api_token 与服务端生成的 api_token 进行校对,如果不相等,则表示验证失败if ($api_token != $api_token_server) {    exit('access deny');  // 拒绝访问}// 5、验证通过,返回数据给客户端//。。。?>

再说第二个token(user_token)

它的职责是保护用户的用户名及密码多次提交,以防密码泄露。

如果接口需要用户登录,其访问流程如下:

用户提交“用户名”和“密码”,实现登录(条件允许,这一步最好走https);

登录成功后,服务端返回一个 user_token,生成规则参考如下:

服务端用数据表维护user_token的状态,表设计如下:

字段名字段类型注释
user_idint用户ID
user_tokenvarchar(36)用户token
expire_timeint过期时间(Unix时间戳)

(注:只列出了核心字段,其它的再扩展吧!!!)

服务端生成 user_token 后,返回给客户端(自己存储),客户端每次接口请求时,如果接口需要用户登录才能访问,则需要把 user_id 与 user_token 传回给服务端,服务端接受到这2个参数后,需要做以下几步:

检测 api_token的有效性;

删除过期的 user_token 表记录;

根据 user_id,user_token 获取表记录,如果表记录不存在,直接返回错误,如果记录存在,则进行下一步;

更新 user_token 的过期时间(延期,保证其有效期内连续操作不掉线);

返回接口数据;

接口用例如下:

发布日志

URL:  http://blog.snsgou.com/blog/Index/addBlog?client_id=wt3734wy636dhd3636sr5858t6&api_token=880fed4ca2aabd20ae9a5dd774711de2&user_token=etye0fgkgk4ca2aabd20ae9a5dd77471fgf&user_id=12  请求方式:  POST

POST参数:title=我是标题&content=我是内容

返回数据:

{
      'code' => 1, // 1:成功 0:失败
      'msg' => '操作成功' // 登录失败、无权访问
      'data' => []
}

以上是“PHP中token如何生成”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

PHP中token如何生成

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

PHP中token如何生成

这篇文章主要为大家展示了“PHP中token如何生成”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“PHP中token如何生成”这篇文章吧。php token的生成接口特点汇总:1、因为是非开放性
2023-06-20

PHP中如何生成缩略图

这篇文章给大家介绍PHP中如何生成缩略图,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。PHP生成缩略图HTML代码< !DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transit
2023-06-17

如何在PHP中使用生成器

这期内容当中小编将会给大家带来有关如何在PHP中使用生成器,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。PHP开发环境搭建工具有哪些一、phpStudy,是一个新手入门最常用的开发环境。二、WampSer
2023-06-14

如何在php中生成唯一ID

这篇文章将为大家详细讲解有关如何在php中生成唯一ID,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。php有什么用php是一个嵌套的缩写名称,是英文超级文本预处理语言,它的语法混合了C、Ja
2023-06-14

如何在 PHP 中生成 JSON 文件

在本文中,我们将介绍在 PHP 中生成 .json 文件的方法。使用 file_put_contents() 函数在 PHP 中使用 file_put_contents() 函数生成一个 json 文件内置函数 file_put_conte
如何在 PHP 中生成 JSON 文件
2024-02-27

如何在PHP中生成随机数

在PHP中生成随机数可以使用内置的rand()函数或者使用random_int()函数,具体如下:1. 使用rand()函数:```php$randomNumber = rand(); // 生成一个随机数$randomNumberInR
2023-08-15

php如何生成随机数

这篇文章主要介绍php如何生成随机数,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!php生成随机数的方法非常简单,因为php内部为我们提供了现成的随机数方法。因此我们并不需要进行额外配置,只需要调用内部方法即可。ph
2023-06-06

asp与php中如何定时生成页面

这篇文章主要介绍asp与php中如何定时生成页面,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!PHP版本的的定时生成页面的:
2023-06-20

php如何生成报错日志

本篇内容主要讲解“php如何生成报错日志”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“php如何生成报错日志”吧!一、php.ini配置文件设置首先,我们需要找到php.ini文件,它通常位于P
2023-07-05

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录