美文网首页
php实现谷歌支付校验的两种方法

php实现谷歌支付校验的两种方法

作者: php转go | 来源:发表于2021-05-27 15:53 被阅读0次

    方式一,访问谷歌接口校验,该校验服务器必须能访问谷歌

    1. 安装谷歌官方拓展
    composer require google/apiclient
    

    官方文档链接:自己谷歌查吧,写了会被锁文章
    github搜索:google-api-php-client

    1. 从控制台下载私钥json文件,内容大致如下
    {
      "type": "service_account",
      "project_id": "xxxxx",
      "private_key_id": "xxx",
      "private_key": "xxx",
      "client_email": "xxx",
      "client_id": "xxx",
      "auth_uri": "xxx",
      "token_uri": "xxx",
      "auth_provider_x509_cert_url": "xxx",
      "client_x509_cert_url": "xxx"
    }
    

    注意:json里面的client_email里面的email需要对这个应用设置管理员权限,设置后需要一段时间才能生效,没有权限,访问则会返回401
    设置管理员权限:
    1,google play控制台,打开菜单“用户和权限》邀请用户”
    2,写邮箱,选择对应的应用,账户权限勾选管理员

    生成json私钥文件方式

    1. 在 Firebase 控制台中,打开设置 >服务帐号
    2. 点击生成新的私钥,然后点击生成密钥进行确认。
    3. 妥善存储包含密钥的 JSON 文件。
    1. 代码实现
           $configLocation = env("CONFIG_PATH").'google-services.json';
            // 将 JSON 设置 环境变量
            putenv('GOOGLE_APPLICATION_CREDENTIALS='.$configLocation);
            // 变量  包名
            $package_name=$receipt['packageName'];
            // 变量  设置的商品ID
            $product_id=$receipt['productId'];
            // 变量  客户端传过来的 purchaseToken
            $purchase_token=$receipt['purchaseToken'];
            try {
                $google_client = new \Google_Client();
                $google_client->useApplicationDefaultCredentials();
                $google_client->addScope(\Google_Service_AndroidPublisher::ANDROIDPUBLISHER);
                $androidPublishService = new \Google_Service_AndroidPublisher($google_client);
                $result = $androidPublishService->purchases_products->get(
                    $package_name,
                    $product_id,
                    $purchase_token
                );
                //purchaseState  0。已购买1.已取消2.待定 consumptionState 0。尚未消耗1.已消耗
                if($result->purchaseState==1 && $result->consumptionState==1){
                   //业务处理
                }
            }catch (Exception $exception){
                return show(0, $exception->getMessage());
            }
    

    方式二,使用公钥进行算法验证

       /**校验谷歌支付
         * @param string $receipt 支付返回给客户端的一串json
         * @param string $signature 支付后返回给客户端的签名字符串
         * @param string $google_public_key 谷歌控制台拿到的公钥
         * @return bool
         */
        public function googlePayVerify(string $receipt,string $signature,string $google_public_key):bool
        {
            $public_key_handle = openssl_pkey_get_public($google_public_key);
            if($public_key_handle===false){
                $public_key = "-----BEGIN PUBLIC KEY-----" . PHP_EOL .
                    chunk_split($google_public_key, 64, PHP_EOL) .
                    "-----END PUBLIC KEY-----";
                $public_key_handle = openssl_pkey_get_public($public_key);
                if($public_key_handle===false){
                    return false;
                }
            }
            $result = openssl_verify($receipt, base64_decode($signature), $public_key_handle, OPENSSL_ALGO_SHA1);
            //从内存中释放和指定的 public_key相关联的密钥
            openssl_free_key($public_key_handle);
             return  $result;
        }
    

    公钥获取方式:
    Google play console-》获利设置-》许可,复制 Base64 编码 RSA 公钥

    相关文章

      网友评论

          本文标题:php实现谷歌支付校验的两种方法

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