苹果支付服务器二次验证

653 阅读2分钟

本文已参与「新人创作礼」活动,一起开启掘金创作之路。

大家好,这篇文章主要记录通过苹果支付的回调验签方式

平时对接支付可能更多用到的是微信、支付宝、银联等支付,但是如果使用app支付的话,尤其是ios上架的时候必须使用苹果内购,使用到苹果内购的话就可以用到该验证方法

以下是验证方法和使用方式,分享给大家!

验证方法

/** 
 * 验证AppStore内付 
 * @param  string $receipt_data 付款后凭证 
 * @return array                验证是否成功 
 */ 
function validate_apple_pay($receipt_data){ 
    /** 
     * 21000 App Store不能读取你提供的JSON对象 
     * 21002 receipt-data域的数据有问题 
     * 21003 receipt无法通过验证 
     * 21004 提供的shared secret不匹配你账号中的shared secret 
     * 21005 receipt服务器当前不可用 
     * 21006 receipt合法,但是订阅已过期。服务器接收到这个状态码时,receipt数据仍然会解码并一起发送 
     * 21007 receipt是Sandbox receipt,但却发送至生产系统的验证服务 
     * 21008 receipt是生产receipt,但却发送至Sandbox环境的验证服务 
     */ 
    function acurl($receipt_data, $sandbox=0){ 
        //小票信息 
        $POSTFIELDS = array("receipt-data" => $receipt_data); 
        $POSTFIELDS = json_encode($POSTFIELDS); 
  
        //正式购买地址 沙盒购买地址 
        $url_buy     = "https://buy.itunes.apple.com/verifyReceipt"; 
        $url_sandbox = "https://sandbox.itunes.apple.com/verifyReceipt"; 
        $url = $sandbox ? $url_sandbox : $url_buy; 
  
        //简单的curl 
        $ch = curl_init($url); 
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
        curl_setopt($ch, CURLOPT_POST, 1); 
        curl_setopt($ch, CURLOPT_POSTFIELDS, $POSTFIELDS); 
        $result = curl_exec($ch); 
        curl_close($ch); 
        return $result; 
    } 
    // 验证参数 
    if (strlen($receipt_data)<20){ 
        $result=array( 
            'status'=>false, 
            'message'=>'非法参数' 
            ); 
        return $result; 
    } 
    // 请求验证 
    $html = acurl($receipt_data); 
    $data = json_decode($html,true); 
  
    // 如果是沙盒数据 则验证沙盒模式 
    if($data['status']=='21007'){ 
        // 请求验证 
        $html = acurl($receipt_data, 1); 
        $data = json_decode($html,true); 
        $data['sandbox'] = '1'; 
    } 
  
    if (isset($_GET['debug'])) { 
        exit(json_encode($data)); 
    } 
      
    // 判断是否购买成功 
    if(intval($data['status'])===0){ 
        $result=array( 
            'status'=>true, 
            'message'=>'购买成功' 
            ); 
    }else{ 
        $result=array( 
            'status'=>false, 
            'message'=>'购买失败 status:'.$data['status'] 
            ); 
    } 
    return $result; 
}

使用方法如下

<?php 
namespace Api\\Controller; 
use Common\\Controller\\HomeBaseController; 
/** 
 * paypal支付 
 */ 
class AppstoreController extends HomeBaseController{ 
     
    // 支付回调 
    public function result(){ 
        //苹果内购的验证收据 
        $receipt_data = I('post.apple_receipt');  
        // 验证支付状态 
        $result=validate_apple_pay($receipt_data); 
        if($result['status']){ 
            // 验证通过 此处可以是修改数据库订单状态等操作 
             
        }else{ 
            // 验证不通过 
        } 
    } 
 
}