美文网首页1
获取 微信授权(支付宝待更新)

获取 微信授权(支付宝待更新)

作者: 只因为趁年轻 | 来源:发表于2018-12-27 11:52 被阅读15次

一、微信授权

1.微信授权比较简单,只需要向微信终端发送一个SendAuthReq消息结构 即可拉取授权。
/**
 发起微信授权
 @param success 成功
 @param failed 失败
 */
- (void)startWeChatAuthSuccess:(AuthSuccessBlock)success faild:(AuthFailedBlock)failed {
    self.isAuth = YES;
    self.authSuccessBlock = success;
    self.authfailedBlock = failed;
    if (!_hasRegisteWeChat) {
        _hasRegisteWeChat = [WXApi registerApp:WX_APP_ID];
    }
    if (![WXApi isWXAppInstalled]) {
        _authfailedBlock?_authfailedBlock(@"您尚未安装微信,请选择其它支付方式"):nil;
        return;
    }
    //开始授权啦
    SendAuthReq *req = [[SendAuthReq alloc] init];
    //应用授权作用域,如获取用户个人信息则填写snsapi_userinfo
    req.scope = @"snsapi_userinfo";
    //用于保持请求和回调的状态,授权请求后原样带回给第三方。该参数可用于防止csrf攻击(跨站请求伪造攻击),建议第三方带上该参数,可设置为简单的随机数加session进行校验
    req.state = @"wechatAuth";
    //第三方向微信终端发送一个SendAuthReq消息结构
    [WXApi sendReq:req];
}
2.处理微信回调,对拿到回调的类型做判断,然后根据code码进行会判断处理,如果有微信支付,当然也要判断state信息是否为 wechatAuth (发送授权信息传入的字符串)
//微信结果回调的方法   收到微信的回应
-(void) onResp:(BaseResp*)resp {
    //授权类型的消息
        /*
         ErrCode    ERR_OK = 0(用户同意)
         ERR_AUTH_DENIED = -4(用户拒绝授权)
         ERR_USER_CANCEL = -2(用户取消)
         code    用户换取access_token的code,仅在ErrCode为0时有效
         state    第三方程序发送时用来标识其请求的唯一性的标志,由第三方程序调用sendReq时传入,由微信终端回传,state字符串长度不能超过1K
         lang    微信客户端当前语言
         country    微信用户当前国家信息
         */
     if ([resp isKindOfClass:[SendAuthResp class]]) {
        SendAuthResp *authResp = (SendAuthResp *)resp;
        switch (resp.errCode) {
            case 0:
            {
                //用户换取access_token的code,仅在ErrCode为0时有效
                if ([authResp.state isEqualToString:@"wechatAuth"]) {
                    [self loginWeixinSuccessWithBaseResp:authResp];
                }
            }
                break;
            case -4:
            {
                if (_authfailedBlock) {
                    _authfailedBlock(@"用户拒绝授权");
                }
            }
                break;
            case -2:
            {
                if (_authfailedBlock) {
                    _authfailedBlock(@"用户取消授权");
                }
            }
                break;
                
            default:
                break;
        }
    }
}
3.通过拿到的授权code来获取用户基本信息

APPID: 应用唯一标识,在微信开放平台提交应用审核通过后获得
SECRET:应用密钥AppSecret,在微信开放平台提交应用审核通过后获得
CODE:拉取授权后得到的授权码
http请求方式: GET
https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code

4.通过上面的接口可以拿到access_tokenrefresh_tokenopenid ,官方文档说access_token2个小时后会过期,为了避免不让这个过期,我们在拿到这三个参数时可以做一些判断刷新token,不让他过期。
微信自己的文档
5.刷新token,获取用户信息
  1. 判断access_token是否过期
    http请求方式: GET
    https://api.weixin.qq.com/sns/auth?access_token=ACCESS_TOKEN&openid=OPENID
  2. 如果过期了拿refresh_token 获取一个新的
    http请求方式: GET
    https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=APPID&grant_type=refresh_token&refresh_token=REFRESH_TOKEN
  3. 根据拿到的access_tokenopenid放心的去获取用户信息吧
    http请求方式: GET
    https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID
    接口频率
    以上方法都是通过HTTP请求获取

二、支付宝授权

相关文章

网友评论

    本文标题:获取 微信授权(支付宝待更新)

    本文链接:https://www.haomeiwen.com/subject/bsqrlqtx.html