微信公众号开发系列-获取微信OpenID

时间:2022-04-17 00:16:24

在微信开发时候在做消息接口交互的时候须要使用带微信加密ID(OpenId),下面讲讲述2中类型方式获取微信OpenID。接收事件推送方式和网页授权获取用户基本信息方式获取。

1、通过接收被动消息方式获取OpenId(接收事件推送方式)。下面事件中都能够获取到OpenID

关注/取消关注事件

用户在关注与取消关注公众号时。微信会把这个事件推送到开发人员填写的URL。方便开发人员给用户下发欢迎消息或者做帐号的解绑。

微信server在五秒内收不到响应会断掉连接,而且又一次发起请求,总共重试三次

关于重试的消息排重,推荐使用FromUserName + CreateTime 排重。

假如server无法保证在五秒内处理并回复,能够直接回复空串,微信server不会对此作不论什么处理,而且不会发起重试。

推送XML数据包演示样例:

<xml>
<ToUserName><![CDATA[toUser]]></ToUserName>
<FromUserName><![CDATA[FromUser]]></FromUserName>
<CreateTime>123456789</CreateTime>
<MsgType><![CDATA[event]]></MsgType>
<Event><![CDATA[subscribe]]></Event>
</xml>

參数说明:

參数 描写叙述
ToUserName 开发人员微信号
FromUserName 发送方帐号(一个OpenID)
CreateTime 消息创建时间 (整型)
MsgType 消息类型,event
Event 事件类型,subscribe(订阅)、unsubscribe(取消订阅)

使用网页调试工具调试该接口

扫描带參数二维码事件

用户扫描带场景值二维码时,可能推送下面两种事件:

  1. 假设用户还未关注公众号,则用户能够关注公众号。关注后微信会将带场景值关注事件推送给开发人员。
  2. 假设用户已经关注公众号。则微信会将带场景值扫描事件推送给开发人员。

1. 用户未关注时,进行关注后的事件推送

推送XML数据包演示样例:

<xml><ToUserName><![CDATA[toUser]]></ToUserName>
<FromUserName><![CDATA[FromUser]]></FromUserName>
<CreateTime>123456789</CreateTime>
<MsgType><![CDATA[event]]></MsgType>
<Event><![CDATA[subscribe]]></Event>
<EventKey><![CDATA[qrscene_123123]]></EventKey>
<Ticket><![CDATA[TICKET]]></Ticket>
</xml>

參数说明:

參数 描写叙述
ToUserName 开发人员微信号
FromUserName 发送方帐号(一个OpenID)
CreateTime 消息创建时间 (整型)
MsgType 消息类型。event
Event 事件类型,subscribe
EventKey 事件KEY值。qrscene_为前缀,后面为二维码的參数值
Ticket 二维码的ticket,可用来换取二维码图片

2. 用户已关注时的事件推送

推送XML数据包演示样例:

<xml>
<ToUserName><![CDATA[toUser]]></ToUserName>
<FromUserName><![CDATA[FromUser]]></FromUserName>
<CreateTime>123456789</CreateTime>
<MsgType><![CDATA[event]]></MsgType>
<Event><![CDATA[SCAN]]></Event>
<EventKey><![CDATA[SCENE_VALUE]]></EventKey>
<Ticket><![CDATA[TICKET]]></Ticket>
</xml>

參数说明:

參数 描写叙述
ToUserName 开发人员微信号
FromUserName 发送方帐号(一个OpenID)
CreateTime 消息创建时间 (整型)
MsgType 消息类型,event
Event 事件类型,SCAN
EventKey 事件KEY值,是一个32位无符号整数,即创建二维码时的二维码scene_id
Ticket 二维码的ticket,可用来换取二维码图片

使用网页调试工具调试该接口

上报地理位置事件

用户允许上报地理位置后,每次进入公众号会话时,都会在进入时上报地理位置,或在进入会话后每5秒上报一次地理位置,公众号能够在公众平台站点中改动以上设置。上报地理位置时,微信会将上报地理位置事件推送到开发人员填写的URL。

推送XML数据包演示样例:

<xml>
<ToUserName><![CDATA[toUser]]></ToUserName>
<FromUserName><![CDATA[fromUser]]></FromUserName>
<CreateTime>123456789</CreateTime>
<MsgType><![CDATA[event]]></MsgType>
<Event><![CDATA[LOCATION]]></Event>
<Latitude>23.137466</Latitude>
<Longitude>113.352425</Longitude>
<Precision>119.385040</Precision>
</xml>

參数说明:

參数 描写叙述
ToUserName 开发人员微信号
FromUserName 发送方帐号(一个OpenID)
CreateTime 消息创建时间 (整型)
MsgType 消息类型,event
Event 事件类型,LOCATION
Latitude 地理位置纬度
Longitude 地理位置经度
Precision 地理位置精度

使用网页调试工具调试该接口

自己定义菜单事件

用户点击自己定义菜单后,微信会把点击事件推送给开发人员,请注意,点击菜单弹出子菜单,不会产生上报。

点击菜单拉取消息时的事件推送

推送XML数据包演示样例:

<xml>
<ToUserName><![CDATA[toUser]]></ToUserName>
<FromUserName><![CDATA[FromUser]]></FromUserName>
<CreateTime>123456789</CreateTime>
<MsgType><![CDATA[event]]></MsgType>
<Event><![CDATA[CLICK]]></Event>
<EventKey><![CDATA[EVENTKEY]]></EventKey>
</xml>

參数说明:

參数 描写叙述
ToUserName 开发人员微信号
FromUserName 发送方帐号(一个OpenID)
CreateTime 消息创建时间 (整型)
MsgType 消息类型,event
Event 事件类型,CLICK
EventKey 事件KEY值。与自己定义菜单接口中KEY值相应

点击菜单跳转链接时的事件推送

推送XML数据包演示样例:

<xml>
<ToUserName><![CDATA[toUser]]></ToUserName>
<FromUserName><![CDATA[FromUser]]></FromUserName>
<CreateTime>123456789</CreateTime>
<MsgType><![CDATA[event]]></MsgType>
<Event><![CDATA[VIEW]]></Event>
<EventKey><![CDATA[www.qq.com]]></EventKey>
</xml>

參数说明:

參数 描写叙述
ToUserName 开发人员微信号
FromUserName 发送方帐号(一个OpenID)
CreateTime 消息创建时间 (整型)
MsgType 消息类型,event
Event 事件类型,VIEW
EventKey 事件KEY值,设置的跳转URL

t=index&type=%E6%B6%88%E6%81%AF%E6%8E%A5%E5%8F%A3%E8%B0%83%E8%AF%95&form=%E4%BA%8B%E4%BB%B6%E6%B6%88%E6%81%AF" class="external text" rel="nofollow" style="color:rgb(54,103,153); text-decoration:none">使用网页调试工具调试该接口

以上信息摘自微信公众平台接收事件推送章节。

title=接收事件推送">点击查看原始帮助文档-接收事件推送

2、通过第三方网页授权方式获取OpenID,採用第三方网页授权(OAuth2.0授权登录)

假设用户在微信中(Web微信除外)訪问公众号的第三方网页。公众号开发人员能够通过此接口获取当前用户基本信息(包含昵称、性别、城市、国家)。利用用户信息,能够实现体验优化、用户来源统计、帐号绑定、用户身份鉴权等功能。

请注意,“获取用户基本信息接口是在用户和公众号产生消息交互时。才干依据用户OpenID获取用户基本信息。而网页授权的方式获取用户基本信息,则无需消息交互,仅仅是用户进入到公众号的网页,就可弹出请求用户授权的界面,用户授权后,就可获得其基本信息(此过程甚至不须要用户已经关注公众号。)”

微信OAuth2.0授权登录让微信用户使用微信身份安全登录第三方应用或站点,在微信用户授权登录已接入微信OAuth2.0的第三方应用后,第三方能够获取到用户的接口调用凭证(access_token),通过access_token能够进行微信开放平台授权关系接口调用,从而可实现获取微信用户基本开放信息和帮助用户实现基础开放功能等。

在微信公众号请求用户网页授权之前,开发人员须要先到公众平台站点的我的服务页中配置授权回调域名。请注意,这里填写的域名不要加http://

关于配置授权回调域名的说明:

授权回调域名配置规范为全域名,比方须要网页授权的域名为:www.qq.com,配置以后此域名下面的页面http://www.qq.com/music.htmlhttp://www.qq.com/login.html 都能够进行OAuth2.0鉴权。

但http://pay.qq.comhttp://music.qq.comhttp://qq.com  无法进行OAuth2.0鉴权。

详细而言,网页授权流程分为四步:

  1. 引导用户进入授权页面允许授权。获取code
  2. 通过code换取网页授权access_token(与基础支持中的access_token不同)
  3. 假设须要,开发人员能够刷新网页授权access_token,避免过期
  4. 通过网页授权access_token和openid获取用户基本信息

文件夹

[隐藏]

第一步:用户允许授权。获取code

在确保微信公众账号拥有授权作用域(scope參数)的权限的前提下(服务号获得高级接口后。默认带有scope參数中的snsapi_base和snsapi_userinfo),引导关注者打开例如以下页面:

https://open.weixin.qq.com/connect/oauth2/authorize?

appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect
若提示“该链接无法訪问”,请检查參数是否填写错误,是否拥有scope參数相应的授权作用域权限。
參考链接(请在微信client中打开此链接体验)
Scope为snsapi_base

https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx520c15f417810387&redirect_uri=http%3A%2F%2Fchong.qq.com%2Fphp%2Findex.php%3Fd%3D%26c%3DwxAdapter%26m%3DmobileDeal%26showwxpaytitle%3D1%26vb2ctag%3D4_2030_5_1194_60&response_type=code&scope=snsapi_base&state=123#wechat_redirect
Scope为snsapi_userinfo
https://open.weixin.qq.com/connect/oauth2/authorize?appid=wxf0e81c3bee622d60&redirect_uri=http%3A%2F%2Fnba.bluewebgame.com%2Foauth_response.php&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect

參数说明

參数 是否必须 说明
appid 公众号的唯一标识
redirect_uri 授权后重定向的回调链接地址,请使用urlencode对链接进行处理
response_type 返回类型。请填写code
scope 应用授权作用域。snsapi_base (不弹出授权页面,直接跳转,仅仅能获取用户openid)。snsapi_userinfo (弹出授权页面,可通过openid拿到昵称、性别、所在地。而且,即使在未关注的情况下。仅仅要用户授权,也能获取其信息
state 重定向后会带上state參数,开发人员能够填写a-zA-Z0-9的參数值
#wechat_redirect 不管直接打开还是做页面302重定向时候。必须带此參数

下图为scope等于snsapi_userinfo时的授权页面:

title=%E6%96%87%E4%BB%B6:%E7%BD%91%E9%A1%B5%E6%8E%88%E6%9D%83.png" class="image" title="网页授权" style="color:rgb(54,103,153); text-decoration:none">微信公众号开发系列-获取微信OpenID

用户允许授权后

假设用户允许授权,页面将跳转至 redirect_uri/?code=CODE&state=STATE。若用户禁止授权。则重定向后不会带上code參数。仅会带上state參数redirect_uri?state=STATE

code说明 :
code作为换取access_token的票据。每次用户授权带上的code将不一样。code仅仅能使用一次,5分钟未被使用自己主动过期。

第二步:通过code换取网页授权access_token

首先请注意,这里通过code换取的网页授权access_token,与基础支持中的access_token不同。

公众号可通过下述接口来获取网页授权access_token。

假设网页授权的作用域为snsapi_base。则本步骤中获取到网页授权access_token的同一时候,也获取到了openid,snsapi_base式的网页授权流程即到此为止。

请求方法

获取code后。请求下面链接获取access_token:
appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code" class="external free" rel="nofollow" style="color:rgb(54,103,153); text-decoration:none">https://api.weixin.qq.com/sns/oauth2/access_token? appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code

參数说明

參数 是否必须 说明
appid 公众号的唯一标识
secret 公众号的appsecret
code 填写第一步获取的code參数
grant_type 填写为authorization_code

返回说明

正确时返回的JSON数据包例如以下:

{
"access_token":"ACCESS_TOKEN",
"expires_in":7200,
"refresh_token":"REFRESH_TOKEN",
"openid":"OPENID",
"scope":"SCOPE"
}
參数 描写叙述
access_token 网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同
expires_in access_token接口调用凭证超时时间。单位(秒)
refresh_token 用户刷新access_token
openid 用户唯一标识,请注意,在未关注公众号时。用户訪问公众号的网页。也会产生一个用户和公众号唯一的OpenID
scope 用户授权的作用域,使用逗号(,)分隔

错误时微信会返回JSON数据包例如以下(演示样例为Code无效错误):

{"errcode":40029,"errmsg":"invalid code"}

title=%E5%85%A8%E5%B1%80%E8%BF%94%E5%9B%9E%E7%A0%81%E8%AF%B4%E6%98%8E" class="external text" rel="nofollow" style="color:rgb(54,103,153); text-decoration:none">全局返回码说明

第三步:刷新access_token(假设须要)

因为access_token拥有较短的有效期,当access_token超时后,能够使用refresh_token进行刷新。refresh_token拥有较长的有效期(7天、30天、60天、90天),当refresh_token失效的后。须要用户又一次授权。

请求方法

获取第二步的refresh_token后。请求下面链接获取access_token:
https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=APPID&grant_type=refresh_token&refresh_token=REFRESH_TOKEN
參数 是否必须 说明
appid 公众号的唯一标识
grant_type 填写为refresh_token
refresh_token 填写通过access_token获取到的refresh_token參数

返回说明

正确时返回的JSON数据包例如以下:

{
"access_token":"ACCESS_TOKEN",
"expires_in":7200,
"refresh_token":"REFRESH_TOKEN",
"openid":"OPENID",
"scope":"SCOPE"
}
參数 描写叙述
access_token 网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同
expires_in access_token接口调用凭证超时时间,单位(秒)
refresh_token 用户刷新access_token
openid 用户唯一标识
scope 用户授权的作用域,使用逗号(,)分隔

错误时微信会返回JSON数据包例如以下(演示样例为Code无效错误):

{"errcode":40029,"errmsg":"invalid code"}

全局返回码说明

第四步:拉取用户信息(需scope为 snsapi_userinfo)

假设网页授权作用域为snsapi_userinfo,则此时开发人员能够通过access_token和openid拉取用户信息了。

请求方法

http:GET(请使用https协议)
https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN

參数说明

參数 描写叙述
access_token 网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同
openid 用户的唯一标识
lang 返回国家地区语言版本号,zh_CN 简体。zh_TW 繁体。en 英语

返回说明

正确时返回的JSON数据包例如以下:

{
"openid":" OPENID",
" nickname": NICKNAME,
"sex":"1",
"province":"PROVINCE"
"city":"CITY",
"country":"COUNTRY",
"headimgurl": "http://wx.qlogo.cn/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ4eMsv84eavHiaiceqxibJxCfHe/46",
"privilege":[
"PRIVILEGE1"
"PRIVILEGE2"
]
}
參数 描写叙述
openid 用户的唯一标识
nickname 用户昵称
sex 用户的性别,值为1时是男性,值为2时是女性。值为0时是未知
province 用户个人资料填写的省份
city 普通用户个人资料填写的城市
country 国家,如中国为CN
headimgurl 用户头像,最后一个数值代表正方形头像大小(有0、46、64、96、132数值可选,0代表640*640正方形头像)。用户没有头像时该项为空
privilege 用户特权信息。json 数组,如微信沃卡用户为(chinaunicom)

错误时微信会返回JSON数据包例如以下(演示样例为openid无效):

{"errcode":40003,"errmsg":" invalid openid "}

全局返回码说明

附:检验授权凭证(access_token)是否有效

请求方法

http:GET(请使用https协议)
https://api.weixin.qq.com/sns/auth? access_token=ACCESS_TOKEN&openid=OPENID

參数说明

參数 描写叙述
access_token 网页授权接口调用凭证,注意:此access_token与基础支持的access_token不同
openid 用户的唯一标识

返回说明

正确的Json返回结果:

{ "errcode":0,"errmsg":"ok"}

错误时的Json返回演示样例:

{ "errcode":40003,"errmsg":"invalid openid"}

以上信息摘自微信公众平台网页授权获取用户基本信息章节。

title=网页授权获取用户基本信息">点击查看原始帮助文档-网页授权获取用户基本信息

很多其它关注付义方技术博客:http://blog.csdn.net/fuyifang 本人新浪微博:http://weibo.com/i/1741159542