ToB企服应用市场:ToB评测及商务社交产业平台

标题: PHP转Go系列 | ThinkPHP与Gin框架之API接口签名计划实践 [打印本页]

作者: 滴水恩情    时间: 2024-7-8 07:26
标题: PHP转Go系列 | ThinkPHP与Gin框架之API接口签名计划实践
各人好,我是码农先森。
追念起以前用模版渲染数据的岁月,那时都没有 API 接口开辟的概念。PHP 服务端和前端 HTML、CSS、JS 代码混淆式开辟,也不分前端、后端程序员,各人都是全干工程师。随着前后端分离、移动端开辟的鼓起,用后端渲染数据的开辟方式效率低下,已经不能满意业务对需求快速上线的要求了。于是为了前后端的高效协同开辟引入了 API 接口,只要在开辟需求之前约定好数据传参,之后便可以开始启动自己的开辟任务且互不干涉,末了再进行统一的接口联调。

根据熵增原则,假如任何事情不加以规则来限制,则都会朝着泛滥的方式发展。同样 API 接口开辟也会出现这样的环境,由于每个人的开辟习惯不同,导致 API 接口的开辟格式五花八门,联调过程困难重重。无规矩不成方圆,因此为了规范 API 接口开辟的情势,同时也结合我平时的项目开辟经验。总结了一些 API 接口开辟的实践经验,希望对各人能有所帮助。
话不多说,开整!
这次重要的实践内容是 API 接口签名计划,以下是一些关键的步骤:
接下来开始在 ThinkPHP 和 Gin 框架中进行实现,文中只展示了焦点的代码,完备代码的获取方式放在了文章末端。
我们先熟悉一下项目结构焦点的目次,有助于理解文中的内容。一个正常的哀求起首要颠末路由 route 再到中心件 middleware 末了到控制器 controller,API 接口的签名验证是在中心件 middleware 中实现,作为一个中心层在整个哀求链路中起着承上启下的重要作用。
  1. [manongsen@root php_to_go]$ tree -L 2
  2. .
  3. ├── go_sign
  4. │   ├── app
  5. │   │   ├── controller
  6. │   │   │   └── user.go
  7. │   │   ├── middleware
  8. │   │   │   └── api_sign.go
  9. │   │   ├── config.go
  10. │   │   └── route.go
  11. │   ├── go.mod
  12. │   ├── go.sum
  13. │   └── main.go
  14. └── php_sign
  15. │   ├── app
  16. │   │   ├── controller
  17. │   │   │   └── User.php
  18. │   │   ├── middleware
  19. │   │   │   └── ApiSign.php
  20. │   │   └── middleware.php
  21. │   ├── composer.json
  22. │   ├── composer.lock
  23. │   ├── config
  24. │   ├── route
  25. │   │   └── app.php
  26. │   ├── think
  27. │   ├── vendor
  28. │   └── .env
复制代码
ThinkPHP

使用 composer 创建基于 ThinkPHP 框架的 php_sign 项目。
  1. [manongsen@root ~]$ pwd
  2. /home/manongsen/workspace/php_to_go/php_sign
  3. [manongsen@root php_sign]$ composer create-project topthink/think php_sign
复制代码
随机字符串必要用到 Redis 进行存储,所以这里必要安装 Redis 扩展包,便于操作 Redis。
  1. [manongsen@root php_sign]$ composer require predis/predis
复制代码
在项目 php_sign 下创建 ApiSign 中心件。
  1. [manongsen@root php_sign]$ php think make:middleware ApiSign
  2. Middleware:app\middleware\ApiSign created successfully.
复制代码
在项目 php_sign 下复制一个 env 配置文件,并且界说好 AppKey。
  1. [manongsen@root php_sign]$ cp .example.env .env
复制代码
API 接口签名的验证是放在框架的中心件中进行实现的,此中时间戳的有效时间设置的是 2 秒,有些朋友会有疑惑为什么是 2 秒?3 秒、5 秒不可吗?这里的有效时间是基于网络通讯的延时考虑的,根据普遍环境延时大概是 2 秒。假如你的服务延时比较长,也可以设置长一些,并没有一个定量的值,话说到这里也提醒一下假如你的接口延时超过 2 秒,大概率必要优化一下代码了。别的,另有一个随机字符串参数,这个参数的目的是为了防止接口被重放,假如做过爬虫的朋友可能对这个会深有感触,这也是防范爬虫的一种手段。
[code]




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4