• 微信 公众号 小程序 授权 unionid 用户信息 实验总结


    -*-*-*-*-*-*-*-*-*--*-*-*-
    1、小程序通过code获取用户openid的接口,如果用户曾经授权并未过期,或者用户关注过同主体的公众号,会带回unionID,但没有用户头像等信息

    2、关注和取消关注:会返回用户OPENID和事件类型(没有unionId和其他信息[信息很少])

    3、通过这个接口获取用户信息,有unionID(前提:公众号必须绑定开放平台[开放平台的注册要有企业资质,不同主体只能绑定5个,相同主体50个])
    https://api.weixin.qq.com/cgi-bin/user/info?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN

    {"subscribe":1,"openid":"xxx","nickname":"***","sex":1,"language":"zh_CN","city":"武汉","province":"湖北","country":"中国","headimgurl":"htttp://-","subscribe_time":1531834805,"unionid":"***","remark":"","groupid":0,"tagid_list":[],"subscribe_scene":"ADD_SCENE_SEARCH","qr_scene":0,"qr_scene_str":""}

    4、公众号登录授权(关注过的),返回open_id和用户的access_token(没有unionID,除非指定scope=snsapi_userinfo)
    https://api.weixin.qq.com/sns/oauth2/access_token?appid=wxee58414660eafe0f&secret=815598b9eaccf4efcf2a6dd37ba8aafe&code=081nGCtC16UWI30pHBqC1InvtC1nGCto&grant_type=authorization_code
    {"access_token":"xxx","expires_in":7200,"refresh_token":"xxx","openid":"oovPVwP49U6d_Noea9RS1_iJpu5I","scope":"snsapi_base"}
    /*引自微信*/
    关于特殊场景下的静默授权
    a、上面已经提到,对于以snsapi_base为scope的网页授权,就静默授权的,用户无感知;
    b、对于已关注公众号的用户,如果用户从公众号的会话或者自定义菜单进入本公众号的网页授权页,即使是scope为snsapi_userinfo,也是静默授权,用户无感知。
    上面的授权链接有一个默认参数:scope
    https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN(这个ACCESS_TOKEN是app的)
    unionid 只有在用户将公众号绑定到微信开放平台帐号后,才会出现该字段。
    调用这个接口的前提是:网页授权作用域为snsapi_userinfo

    5、小程序授权接口可以获取unionID
    a、前提:用户关注了同一主体的公众号(取消关注后不再返回)
    通过接口:/sns/jscode2session?appid=%s&secret=%s&js_code=%s&grant_type=authorization_code 返回:{"openid":"oOMYa0aUgjAeqEguLnIGkbQCIT-k","unionid":null}

    6、通过公众号的用户信息接口获取小程序的用户信息(cgi-bin/user/info),会报:api unauthorized

    7、小程序得到的code也可以使用公众号的授权接口(能获取到小程序的openid[没有用户信息])
    而且有可能通过指定scope=snsapi_userinfo,获取到unionID(猜想,没有测试)

    8、关于微信自动回复等事件

    客服接待了这个用户,文本消息事件(用户发送消息),就不会发事件给服务器端了(相当于自动回复失效)
    客服接待时,会向服务端发送event:kf_create_session的通知

    9、如果用户未关注公众号,静默授权后请求/cgi-bin/user/info,只有openid,没有头像、昵称、unionid

    关于小程序获取unionid的方法,官方链接:https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/union-id.html

  • 相关阅读:
    Webapi通过报文获取post上来的数据
    Jquery的跨域调用
    @html.ActionLink的几种参数格式
    MVC中使用RadioButtonFor
    string、Empty和null三者的区别
    JQuery中$.ajax()方法参数详解
    多线程与异步的区别
    IEnumerable,ICollection,IList,List之间的区别
    win10锁屏或睡眠一段时间后弹不出登录框
    ssh简明安全规划
  • 原文地址:https://www.cnblogs.com/Denny_Yang/p/9284681.html
Copyright © 2020-2023  润新知