QQ第三方登陆的那些坑(不同应用的用户openid不一致),存量用户OpenID转UnionID的方法

   在准备发布NiterApp 的时候发现QQ互联平台下不同应用的openid是不一致的,由于qq互联web版和app版的应用不同,所以同一用户授权登录后获取到的openid是不同的。换句话说,因为之前数据库存储的是用户的openid,所以同一用户在web端和app端授权后将会创建、登录一个不同的账号。这样是肯定不符合需求的。为了不同应用之间进行用户信息互通,NiterForum最新版本将保存用户的unionID

      但可通过unionID来获取用户的基本信息。强烈建议,如果你拥有多个移动应用、网站应用,可通过获取用户的unionID来区分用户的唯一性,因为只要是同一QQ互联平台下的不同应用,unionID是相同的。换句话说,同一用户,对同一个QQ互联平台下的不同应用,unionID是相同的。(UnionID介绍)

      https请求方式:GET:https://graph.qq.com/oauth2.0/me?access_token=ACCESSTOKEN&unionid=1

      在qq互联官网已支持自助获取getUnionID接口,详见:QQ互联UnionID打通业务自助处理指引

   QQ第三方登陆的那些坑(不同应用的用户openid不一致),存量用户OpenID转UnionID的方法_第1张图片

     但是看到此不要高兴得太早,如果你原来有web或者app应用并且有留存用户数据。那么好了,不同应用的用户的 OPENID 还是不同的 ,只有unionid 才会相同。现有的me接口支持获取unionid,但需要带token。如果token过期,存量用户将无法转换。因此qq互联提供免token转换接口get_ unionid。 该接口不对外公开使用,需要开发者申请使用。

     也就是说,你需要发邮件给[email protected], 申请 存量用户 转为 unionid 的临时接口, 并提供临时接口使用的APPID 和APPKEY。然后大概需要等待大概一周左右的时间。

     拿到临时接口后, 按照再次回复中临时接口的使用方法,遍历所有每个用户的原有OPENID ,再查询到新的 unionid,然后更新原有登陆凭证即可。

     建议
(1)应该注意保存openID、unionID信息,以便以后在不同应用之间进行用户信息互通;
(2)同一开发者名下最多支持60个应用进行UnionID打通;
(3) unionID至少是36个字节长度,建议预留64字节存储空间。

本文同步于:https://niter.cn/p/193

你可能感兴趣的:(java,springboot,javaweb,qq,openid,bug,app,bbs)