PC 微信扫码登陆 (2)

接口封装

private static String qrconnect_url = "https://open.weixin.qq.com/connect/qrconnect"; /** * 生成网页二维码授权链接 * @param appId 应用id * @param redirect_uri 回跳地址 * @return url */ public static String getQrConnectURL(String appId, String redirect_uri) { return getQrConnectURL(appId, redirect_uri, null); } /** * 生成网页二维码授权链接 * @param appId 应用id * @param redirect_uri 回跳地址 * @param state 重定向后会带上state参数,开发者可以填写a-zA-Z0-9的参数值,最多128字节 * @return url */ public static String getQrConnectURL(String appId, String redirect_uri, String state) { Map<String, String> params = new HashMap<String, String>(); params.put("appid", appId); params.put("response_type", "code"); params.put("redirect_uri", redirect_uri); params.put("scope", "snsapi_login"); if (StrKit.isBlank(state)) { params.put("state", "wx#wechat_redirect"); } else { params.put("state", state.concat("#wechat_redirect")); } String para = PaymentKit.packageSign(params, false); return qrconnect_url + "?" + para; }

接口测试

1、设置AppId、APPSecret以及回调域名
2、PC访问测试。开源项目中访问地址为:

域名/[项目名称]/toWebOauth

设置AppId、APPSecret以及回调域名

//pc扫描登陆 public void toWebOauth(){ String calbackUrl=PropKit.get("domain")+"/oauth/webCallBack"; String url=SnsAccessTokenApi.getQrConnectURL(PropKit.get("webAppId"), calbackUrl,"666"); redirect(url); }

如果授权回调域名与开发平台中的填写不一致将会出现以下提示

回调域名与接口调用时填写的域名不一致

第二步:通过code获取access_token 第三步:通过access_token调用接口获取用户信息

第二步、第三步过程与微信公众号授权登录一样可以参考之前写的一篇文章授权获取用户信息

授权后接口调用(UnionID)

获取用户个人信息(UnionID机制)

此接口用于获取用户个人信息。开发者可通过OpenID来获取用户基本信息。特别需要注意的是,如果开发者拥有多个移动应用、网站应用和公众帐号,可通过获取用户基本信息中的unionid来区分用户的唯一性,因为只要是同一个微信开放平台帐号下的移动应用、网站应用和公众帐号,用户的unionid是唯一的。换句话说,同一用户,对同一个微信开放平台下的不同应用,unionid是相同的。请注意,在用户修改微信头像后,旧的微信头像URL将会失效,因此开发者应该自己在获取用户信息后,将头像图片保存下来,避免微信头像URL失效后的异常情况。

官方介绍文档

接口封装可以参考开源项目中

网页授权(公众号、PC)获取用户信息

import com.jfinal.kit.StrKit; import com.jfinal.weixin.sdk.kit.ParaMap; import com.jfinal.weixin.sdk.kit.PaymentKit; import com.jfinal.weixin.sdk.utils.HttpUtils; import com.jfinal.weixin.sdk.utils.RetryUtils; import java.util.HashMap; import java.util.Map; import java.util.concurrent.Callable; public class SnsAccessTokenApi { private static String url = "https://api.weixin.qq.com/sns/oauth2/access_token?grant_type=authorization_code"; private static String authorize_uri = "https://open.weixin.qq.com/connect/oauth2/authorize"; private static String qrconnect_url = "https://open.weixin.qq.com/connect/qrconnect"; /** * 生成Authorize链接 * @param appId 应用id * @param redirect_uri 回跳地址 * @param snsapiBase snsapi_base(不弹出授权页面,只能拿到用户openid)snsapi_userinfo(弹出授权页面,这个可以通过 openid 拿到昵称、性别、所在地) * @return url */ public static String getAuthorizeURL(String appId, String redirect_uri, boolean snsapiBase) { return getAuthorizeURL(appId, redirect_uri, null, snsapiBase); } /** * 生成Authorize链接 * @param appId 应用id * @param redirectUri 回跳地址 * @param state 重定向后会带上state参数,开发者可以填写a-zA-Z0-9的参数值,最多128字节 * @param snsapiBase snsapi_base(不弹出授权页面,只能拿到用户openid)snsapi_userinfo(弹出授权页面,这个可以通过 openid 拿到昵称、性别、所在地) * @return url */ public static String getAuthorizeURL(String appId, String redirectUri, String state, boolean snsapiBase) { Map<String, String> params = new HashMap<String, String>(); params.put("appid", appId); params.put("response_type", "code"); params.put("redirect_uri", redirectUri); // snsapi_base(不弹出授权页面,只能拿到用户openid) // snsapi_userinfo(弹出授权页面,这个可以通过 openid 拿到昵称、性别、所在地) if (snsapiBase) { params.put("scope", "snsapi_base"); } else { params.put("scope", "snsapi_userinfo"); } if (StrKit.isBlank(state)) { params.put("state", "wx#wechat_redirect"); } else { params.put("state", state.concat("#wechat_redirect")); } String para = PaymentKit.packageSign(params, false); return authorize_uri + "?" + para; } /** * 生成网页二维码授权链接 * @param appId 应用id * @param redirect_uri 回跳地址 * @return url */ public static String getQrConnectURL(String appId, String redirect_uri) { return getQrConnectURL(appId, redirect_uri, null); } /** * 生成网页二维码授权链接 * @param appId 应用id * @param redirect_uri 回跳地址 * @param state 重定向后会带上state参数,开发者可以填写a-zA-Z0-9的参数值,最多128字节 * @return url */ public static String getQrConnectURL(String appId, String redirect_uri, String state) { Map<String, String> params = new HashMap<String, String>(); params.put("appid", appId); params.put("response_type", "code"); params.put("redirect_uri", redirect_uri); params.put("scope", "snsapi_login"); if (StrKit.isBlank(state)) { params.put("state", "wx#wechat_redirect"); } else { params.put("state", state.concat("#wechat_redirect")); } String para = PaymentKit.packageSign(params, false); return qrconnect_url + "?" + para; } /** * 通过code获取access_token * * @param code 第一步获取的code参数 * @param appId 应用唯一标识 * @param secret 应用密钥AppSecret * @return SnsAccessToken */ public static SnsAccessToken getSnsAccessToken(String appId, String secret, String code) { final Map<String, String> queryParas = ParaMap.create("appid", appId).put("secret", secret).put("code", code).getData(); return RetryUtils.retryOnException(3, new Callable<SnsAccessToken>() { @Override public SnsAccessToken call() throws Exception { String json = HttpUtils.get(url, queryParas); return new SnsAccessToken(json); } }); } }

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zwsyzs.html