Skip to content

Latest commit

 

History

History
64 lines (41 loc) · 1.85 KB

access_token.md

File metadata and controls

64 lines (41 loc) · 1.85 KB

title: Access Token

SDK 中有一个 Access Token 对象,它是一个全局使用的东西,请把它与 OAuth 中的 code 换取的 Access Token 区别开。

我们一个 SDK 应用在初始化以后,你可以在任何时机从应用中拿到该配置下的 Access Token 实例:

use EasyWeChat\Foundation\Application;

$options = [
    //...
];

$app = new Application($options);

// 获取 access token 实例
$accessToken = $app->access_token; // EasyWeChat\Core\AccessToken 实例
$token = $accessToken->getToken(); // token 字符串
$token = $accessToken->getToken(true); // 强制重新从微信服务器获取 token.

修改 $app 的 Access Token

$app['access_token'] = $newAccessToken; // 生成方式见“生成自定义 Access Token”

生成自定义 Access Token

如果你想生成自定义 appId 的 Access Token 实例,它的构造方法如下:

use EasyWeChat\Core\AccessToken;

$appId = 'YOUR APPID';
$secret = 'YOUR SECRET';

$accessToken = new AccessToken($appId, $secret);
$token = $accessToken->getToken(); // token 字符串

你也可以自定义 token 的缓存方式,把一个实现了 Doctrine\Common\Cache\Cache 缓存接口的实例作为 AccessToken 构造函数的第三个参数传入即可:

本项目使用 doctrine/cache 来完成缓存工作,它支持几乎目前所有的缓存引擎。

以 Redis 为例:

use Doctrine\Common\Cache\RedisCache; // RedisCache 实例了 `Doctrine\Common\Cache\Cache` 接口

$cache = new RedisCache();

// 创建 redis 实例
$redis = new Redis();
$redis->connect('redis_host', 6379);

$cache->setRedis($redis);

$accessToken = new AccessToken($appId, $secret, $cache);
$token = $accessToken->getToken(); // token 字符串