获取关注了关注了公众号微信用户的openid

本文深入探讨了微信开放平台提供的用户管理API,包括通过标签获取用户列表、获取所有用户的OpenID,以及通过授权码获取访问令牌的方法。文章详细介绍了如何使用Spring框架和RestTemplate进行HTTP请求,展示了具体的代码实现。

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


import com.google.common.collect.Maps;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;
import org.springframework.web.util.UriComponentsBuilder;

import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;


@Service
@Slf4j
public class WechatUserService {

    private final static String GET_TAG_USERS_URL = "https://api.weixin.qq.com/cgi-bin/user/tag/get";
    private final static String GET_ALL_USER_OPENID_URL = "https://api.weixin.qq.com/cgi-bin/user/get";
    private static final String GET_ACCESS_TOKEN_URL ="https://api.weixin.qq.com/sns/oauth2/access_token";
    @Autowired
    private OfficialAccountsManager officialAccountsManager;
    @Autowired
    private AccessTokenManagerCenter accessTokenManagerCenter;


    @Autowired
    private RestTemplate restTemplate;


    public List<String> getOpenIdsByTag(String tagId, String nextOpenId) {
        Map<String, Object> body = new HashMap<>();
        body.put("tagid", tagId);
        body.put("next_openid", nextOpenId);
        String result = restTemplate.postForObject(getTagUsersCompleteUrl(), body, String.class);
        if (result != null && result.contains("count")) {
            JSONObject data = JSON.parseObject(result).getJSONObject("data");
            return data.getJSONArray("openid").toJavaList(String.class);
        }
        throw new WechatRequestException("获取标签用户列表失败:" + result);
    }


    private String getTagUsersCompleteUrl() {
        return UriComponentsBuilder.fromHttpUrl(GET_TAG_USERS_URL)
                .queryParam("access_token", accessTokenManagerCenter.getAccessToken())
                .build().toUri().toString();
    }

    private String getAllUserCompleteUrl() {
        return UriComponentsBuilder.fromHttpUrl(GET_ALL_USER_OPENID_URL)
                .queryParam("access_token", accessTokenManagerCenter.getAccessToken())
                .build().toUri().toString();
    }


    private String accessTokenUrl(String code) {
        return UriComponentsBuilder.fromHttpUrl(GET_ACCESS_TOKEN_URL)
                .queryParam("appid", officialAccountsManager.getAppId())
                .queryParam("secret", officialAccountsManager.getAppSecret())
                .queryParam("code", code)
                .queryParam("grant_type", "authorization_code")
                .build().toUri().toString();
    }

     public String getAccessTokenByCode(String code) {
         String url = accessTokenUrl(code);
         return restTemplate.getForObject(url, String.class);
     }

    public List<String> getAllOpenId(String next_openid) {
        //return getOpenIdsByTag("100","");
        Map<String, Object> requestParams = Maps.newHashMap();
        requestParams.put("next_openid", next_openid);
        String result = restTemplate.postForObject(getAllUserCompleteUrl(), requestParams, String.class);
        if (result != null && result.contains("count")) {
            JSONObject data = JSON.parseObject(result).getJSONObject("data");
            return data.getJSONArray("openid").toJavaList(String.class);
        }
        return Collections.emptyList();
    }
}

 

### 获取微信公众号用户OpenID 为了获取微信公众号用户OpenID,通常采用 OAuth2 授权机制来实现。当用户同意授权后,开发者可以利用获得的 code 参数去换取 access_token 和 openid。 #### 使用OAuth2.0授权码模式获取OpenID 构建授权链接如下所示: ```plaintext https://open.weixin.qq.com/connect/oauth2/authorize? appid=APPID& redirect_uri=REDIRECT_URI& response_type=code& scope=snsapi_base& state=STATE#wechat_redirect ``` 其中 `APPID` 是应用唯一标识,在完成微信公众平台注册后可得到;`REDIRECT_URI` 表示回调地址,即授权后的跳转页面路径;`SCOPE` 设置为 `snsapi_base` 可仅获取用户OpenID[^3]。 一旦用户点击此链接并确认授权,则会重定向至指定 URL 并附带一个临时票据 `code` 参数。随后可以通过 POST 请求向 `/sns/oauth2/access_token` 发送请求以交换该 `code` 来取得包含有 OpenID 的响应数据包。 POST 请求参数列表: - grant_type (固定值 "authorization_code") - appid (第三方用户唯一凭证) - secret (第三方用户唯一凭证密钥, 即appsecret) - code (填写第一步获取的code参数) API 地址: ```plaintext https://api.weixin.qq.com/sns/oauth2/access_token?grant_type=authorization_code&appid=APPID&secret=SECRET&code=CODE ``` 返回 JSON 数据样例: ```json { "access_token":"ACCESS_TOKEN", "expires_in":7200, "refresh_token":"REFRESH_TOKEN", "openid":"OPENID", "scope":"SCOPE" } ``` 上述过程中所提到的 `OPENID` 就是代表当前登录者的身份识别符,可用于后续的消息推送等功能开发中[^1]。 对于 Java 开发者来说,还需要确保服务器端已准备好用于验证签名的文件,并可通过公网访问,以便顺利完成整个流程中的安全校验部分[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值