PHP正确写API

举报
黄啊码 发表于 2022/06/29 01:05:42 2022/06/29
【摘要】 原理:用户根据账号密码获取对应token,然后服务端在返回token的时候顺便将其写在文件【session】或者数据库中,第二次请求:客户端通过url携带token发送请求,服务端在接受请求的时候根据client_id找到对应的秘钥,用秘钥得到加密的token,对比token是否相等。 现在的接口基本是mvc模式,URL基本是restf...

  
  1. 原理:用户根据账号密码获取对应token,然后服务端在返回token的时候顺便将其写在文件【session】或者数据库中,第二次请求:客户端通过url携带token发送请求,服务端在接受请求的时候根据client_id找到对应的秘钥,用秘钥得到加密的token,对比token是否相等。
  2. 现在的接口基本是mvc模式,URL基本是restful风格,URL大体格式如下:
  3. http://www.api.com/模块名/控制器名/方法名?参数名1=参数值1&参数名2=参数值2
  4. 接口token生成规则参考如下:   
  5. $api_token = md5 ('模块名' + '控制器名' + '方法名' + '2021-5-18' + '加密密钥') = 987fed3842aabd834e9a5dd73435532de2
  6.     1.'2021-5-18' 为当天时间
  7.     2.'加密密钥'为私有的加密密钥,手机端需要在服务端注册一个“接口使用者”账号后,系统会分配一个账号及密码,数据表设计参考如下:
  8.       字段名及字段类型:
  9. client_id varchar(20) 客户端ID
  10. client_secret varchar(20) 客户端(加密)密钥
  11.       服务端接口校验,PHP实现流程如下:
  12. <?php
  13. //获取GET参数值
  14. $module = $_GET['module'];
  15. $controller = $_GET['controller']
  16. $action = $_GET['action'];
  17. $client_id = $_GET['client_id'];
  18. $api_token = $_GET[''api_token];
  19. //根据客户端传过来的client_id,查询数据库,获取对应的client_secret
  20. $client_secret = getClientSecret($client_id);
  21. //服务端重新生成一个api_token
  22. $api_token_server = md5($module . $controller . $action . date('Y-m-d', time()) . $client_secret);
  23. //客户端传过来的api_token与服务端生成的api_token进行校对,如果不相等,则表示验证失败
  24. if ($api_token != $api_token_server) {
  25. exit('access deny'); //拒绝访问
  26. }
  27. //验证通过,返回数据给客户端
  28. ?>

 

文章来源: markwcm.blog.csdn.net,作者:黄啊码,版权归原作者所有,如需转载,请联系作者。

原文链接:markwcm.blog.csdn.net/article/details/116235577

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。