PHP前端开发

PHP Session缓存微信Token失效:第一次请求为空的解决方法?

百变鹏仔 1个月前 (12-15) #PHP
文章标签 解决方法

php session 中缓存 token 的问题

在 php 代码中,开发者遇到了一个问题:使用 session 缓存微信 api 访问令牌 (token) 时,第一次请求会获取到一个空的 token,而第二次请求才会获得有效 token。

具体代码如下:

header("content-type:text/html;charset=utf-8");session_start();// ...if (!empty($_session['access_token']) && $_session['expire_time'] > time()) {    $url = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" . $_session['access_token'];    // ...    $output = curl_exec($curl);    // ...} else {    // ...    $access_token = $output["access_token"];    // ...}

问题分析:

立即学习“PHP免费学习笔记(深入)”;

开发者在代码中判断,如果 session 中存在 access_token 且未过期,则直接使用,否则请求微信接口获取 access_token 并将其存储在 session 中。但问题在于,如果 session 中不存在 access_token,那么代码将只执行获取 token 的逻辑,而不会执行业务逻辑。

最佳实践:

正确的做法应该是:

if (empty($_SESSION['access_token']) || $_SESSION['expire_time'] <= time()) {    // ...    $access_token = $output["access_token"];    // ...}$url = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" . $_SESSION['access_token'];// ...

这样一来,无论 session 中是否存在 access_token,代码都会先判断是否存在或是否过期,不存在或过期则获取新的 access_token,然后执行业务逻辑。