微信公众号开发-获取access_token

本文介绍了一种用于获取和管理微信平台AccessToken的方法,包括如何通过API调用获取AccessToken、利用缓存提高效率以及更新缓存的具体实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Model——AccessToken
//微信通用接口凭证
public class AccessToken {
    // 获取到的凭证
    private String token;
    // 获取到ticket
    private String ticket;
    // 凭证有效时间,单位:秒
    private int expiresIn;
    // 添加时间
    private long addTime;
}
获取AccessToken外部调用方法getAccessToken,
public final static String access_token_url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET";

public static String getAccessToken(String appId,String secret) {
    AccessToken accessTocken = getAccessToken(appId, secret,System.currentTimeMillis()/1000);//毫秒转秒
    return accessTocken.getToken();
}


public static AccessToken getAccessToken(String appid, String appsecret, long currentTime) {
    AccessToken tockenTicketCache = getTokenTicket(TOKEN);//从缓存中获取
    AccessToken accessToken = null;
    if (tockenTicketCache != null && 
        (currentTime - tockenTicketCache.getAddTime() <= tockenTicketCache.getExpiresIn() )) {
        // 缓存存在并且没过期
        log.info("==========缓存中token已获取时长为:" + (currentTime - tockenTicketCache.getAddTime()) + "秒,可以重新使用");
            return tockenTicketCache;
        }
    JSONObject jsonObject = httpRequest(requestUrl, "GET", null);
    if (null != jsonObject) {//重新请求获取
        accessToken = new AccessToken();
        accessToken.setToken(jsonObject.getString("access_token"));
        // 正常过期时间是7200秒,此处设置3600秒读取一次
        accessToken.setExpiresIn(jsonObject.getIntValue("expires_in") / 2);
        log.info("==========tocket缓存过期时间为:" + accessToken.getExpiresIn() + "秒");
        accessToken.setAddTime(currentTime);
        updateAccessToken(TOKEN, accessToken);//更新缓存
    }
}


    /**
     * 从缓存中读取token或者ticket
     * 
     * @return
     */
    private static AccessToken getTokenTicket(String key) {
        if (TOKEN_TICKET_CACHE != null && TOKEN_TICKET_CACHE.get(key) != null) {
            log.info("==========从缓存中获取到了" + key + "成功===============");
            return TOKEN_TICKET_CACHE.get(key);
        }
        return null;
    }
// token,ticket缓存,
//类加载的时候(第一次访问),这个类中所有静态成员就会被加载在静态存储区,同时存储在静态变量区域的成员一旦创建,直到程序退出才会被回收。
public static Map<String, AccessToken> TOKEN_TICKET_CACHE = new HashMap<String, AccessToken>();
// 获取access_token的接口地址(GET) 限2000(次/天)

    /**
     * 更新缓存中token或者ticket
     * 
     * @return
     */
    private static void updateAccessToken(String key, AccessToken accessTocken) {
        if (TOKEN_TICKET_CACHE != null && TOKEN_TICKET_CACHE.get(key) != null) {
            TOKEN_TICKET_CACHE.remove(key);
            log.info("==========从缓存中删除" + key + "成功===============");
        }
        TOKEN_TICKET_CACHE.put(key, accessTocken);
        cacheAddTime = String.valueOf(accessTocken.getAddTime());// 更新缓存修改的时间
        log.info("==========更新缓存中" + key + "成功===============");
    }



    /**
     * 发起https请求并获取结果
     * 
     * @param requestUrl
     *            请求地址
     * @param requestMethod
     *            请求方式(GET、POST)
     * @param outputStr
     *            提交的数据
     * @return JSONObject(通过JSONObject.get(key)的方式获取json对象的属性值)
     */
    private static JSONObject httpRequest(String requestUrl, String requestMethod, String outputStr) {
        JSONObject jsonObject = null;
        StringBuffer buffer = new StringBuffer();
        try {
            // 创建SSLContext对象,并使用我们指定的信任管理器初始化
            TrustManager[] tm = { new MyX509TrustManager() };
            SSLContext sslContext = SSLContext.getInstance("SSL", "SunJSSE");
            sslContext.init(null, tm, new java.security.SecureRandom());
            // 从上述SSLContext对象中得到SSLSocketFactory对象
            SSLSocketFactory ssf = sslContext.getSocketFactory();

            URL url = new URL(requestUrl);
            HttpsURLConnection httpUrlConn = (HttpsURLConnection) url.openConnection();
            httpUrlConn.setSSLSocketFactory(ssf);

            httpUrlConn.setDoOutput(true);
            httpUrlConn.setDoInput(true);
            httpUrlConn.setUseCaches(false);
            // 设置请求方式(GET/POST)
            httpUrlConn.setRequestMethod(requestMethod);
            if ("GET".equalsIgnoreCase(requestMethod))
                httpUrlConn.connect();
            // 当有数据需要提交时
            if (null != outputStr) {
                OutputStream outputStream = httpUrlConn.getOutputStream();
                // 注意编码格式,防止中文乱码
                outputStream.write(outputStr.getBytes("UTF-8"));
                outputStream.close();
            }
            // 将返回的输入流转换成字符串
            InputStream inputStream = httpUrlConn.getInputStream();
            InputStreamReader inputStreamReader = new InputStreamReader(inputStream, "utf-8");
            BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
            String str = null;
            while ((str = bufferedReader.readLine()) != null) {
                buffer.append(str);
            }
            bufferedReader.close();
            inputStreamReader.close();
            // 释放资源
            inputStream.close();
            inputStream = null;
            httpUrlConn.disconnect(); 
            jsonObject = JSONObject.parseObject(buffer.toString());
            // jsonObject = JSONObject.fromObject(buffer.toString());
        } catch (ConnectException ce) {
            log.info("Weixin server connection timed out.");
        } catch (Exception e) {
            log.info("https request error:{}" + e.getMessage());
        }
        return jsonObject;
    }
微信公众号开发中,获取`access_token`是一个关键步骤,用于授权给你的应用访问微信接口的权限。以下是一般的流程: 1. **申请开发者账号**:首先,你需要在微信公众平台上注册一个开发者账号。 2. **设置AppID**: 获取到账号后,创建或管理你的公众号,获取AppID(应用程序标识)。 3. **获取URL和密钥**:微信公众平台会提供一个服务器配置地址,包括一个加密签名(Secret),以及用来接收微信服务器消息的URL。 4. **发送请求**:使用AppID、Secret和上述配置,按照官方文档中的示例,构建HTTP GET请求到`https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={AppID}&secret={Secret}`。 示例: ```javascript const axios = require('axios'); async function getToken(appId, appSecret) { try { const response = await axios.get( 'https://api.weixin.qq.com/cgi-bin/token', { params: { grant_type: 'client_credential', appid: appId, secret: appSecret } } ); return response.data.access_token; // 返回的就是access_token值 } catch (error) { console.error('Error fetching access token:', error); throw error; } } ``` 5. **存储和刷新**:通常情况下,你需要定期刷新access_token,因为它的有效期较短(一般7200秒)。可以在每次调用需要此令牌的接口前检查其是否过期,如果过期则重新获取。 6. **安全考虑**:确保所有的请求和通信都是HTTPS,不要在前端直接暴露密钥,最好存储在一个安全的地方并只在后端使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值