微信公众号开发中的openid值并不是固定的

转载:http://blog.youkuaiyun.com/u014062332/article/details/29560437?locationNum=4&fps=1


在做微信开发时,今天犯了一个错误,检查了半天才检查出来。微信在向第三方推送信息时会带上一个openid 这是发送信息者的唯一标识,看文档说是唯一标识 就以为这个id只与微信号有关,而今天才发现,openid=加密(微信号+公众号),所以,在不同的微信公众号中,openid是不同的。

文档原话:

用户向公众号发送消息时,公众号方收到的消息发送者是一个OpenID,是使用用户微信号加密后的结果,每个用户对每个公众号有一个唯一的OpenID。

### 获取微信公众号用户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、付费专栏及课程。

余额充值