支付宝 APP登录 获取用户信息 PHP

2 篇文章 0 订阅
1 篇文章 0 订阅

支付宝APP登录服务端流程如下:
1、换取授权访问令牌
2、查询用户信息

APP调用sdk组装授权登录请求(系统交互流程),成功后,支付宝会返回 auth_code,利用此 auth_code 请求 PHP,PHP接收到参数后,先利用 auth_code 获取到 授权访问令牌 access_token(接口文档),再根据 access_token 来获取用户信息(接口文档)。

具体代码如下:

try {
        $code = trim($_POST['auth_code']);
        if (empty($code)) {
            throw new Exception('缺少参数', 0);
        }

        //获取access_token
        $aop = new AopClient ();
        $aop->gatewayUrl = 'https://openapi.alipay.com/gateway.do';
        $aop->appId = $alipay_config['app_id'];
        $aop->rsaPrivateKey = trim($alipay_config['application_private']);
        $aop->format = 'json';
        $aop->charset = 'UTF-8';
        $aop->signType = 'RSA2';
        $aop->alipayrsaPublicKey = trim($alipay_config['alipay_public']);
        $aop->apiVersion = '1.0';
        $request = new AlipaySystemOauthTokenRequest();
        $request->setGrantType("authorization_code");
        $request->setCode($code);

        $result = $aop->execute($request);
        $responseNode = str_replace(".", "_", $request->getApiMethodName()) . "_response";
        $resultData = (array) $result->$responseNode;
        if (empty($resultData['access_token'])) {
            throw new Exception('获取access_token失败', 0);
        }
        //获取用户信息
        $request = new AlipayUserInfoShareRequest ();
        $result = $aop->execute ( $request , $resultData['access_token'] );
        $responseNode = str_replace(".", "_", $request->getApiMethodName()) . "_response";
        $userData = (array) $result->$responseNode;
        if (empty($userData['code']) || $userData['code'] != 10000) {
            throw new Exception('获取用户信息失败', 0);
        }
        /**
         * user_id  支付宝用户的userId
         * avatar   用户头像地址
         * province 省份名称
         * city 市名称。
         * nick_name    用户昵称
         * is_student_certified 是否是学生
         * user_type    用户类型(1/2)  1代表公司账户2代表个人账户
         * user_status  用户状态(Q/T/B/W)。 Q代表快速注册用户 T代表已认证用户 B代表被冻结账户 W代表已注册,未激活的账户
         * is_certified 是否通过实名认证。T是通过 F是没有实名认证。
         * gender   性别(F:女性;M:男性)。
         *
         */

        //业务逻辑


        echo json_encode(['code' => 1, 'msg' => '登录成功']);
        exit;
    } catch (Exception $exception) {
        echo json_encode(['code' => $exception->getCode(), 'msg' => $exception->getMessage()]);
        exit;
    }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值