苹果支付(内购项目)回调验证

返回的加密参数-苹果支付返回的参数  $receipt_data="MIIbWQYJKoZIhvcNAQcCoIIbSjCCG0YCAQExCzAJBgUrDgMCGgUA......";



	function validate_apple_pay($receipt_data) { 
//		$receipt_data='dsfsfs';
	    /**  
	     * 21000  App Store无法读取您提供的JSON对象。
	     * 21002 该receipt-data属性中的数据格式错误或丢失。
	     * 21003 收据无法认证。
	     * 21004 您提供的共享密码与您帐户的文件共享密码不匹配。
	     * 21005 收据服务器当前不可用。
	     * 21006 该收据有效,但订阅已过期。当此状态代码返回到您的服务器时,收据数据也会被解码并作为响应的一部分返回。仅针对自动续订的iOS 6样式交易收据返回。
	     * 21007 该收据来自测试环境,但已发送到生产环境以进行验证。而是将其发送到测试环境。
	     * 21008 该收据来自生产环境,但是已发送到测试环境以进行验证。而是将其发送到生产环境。
	     * 21010 此收据无法授权。就像从未进行过购买一样对待。
	     * 21100-21199 内部数据访问错误。
	     * 在测试环境中,https://sandbox.itunes.apple.com/verifyReceipt用作URL。在生产中,https://buy.itunes.apple.com/verifyReceipt用作URL。
	     */   
	    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;     
	        $url = $url_buy;     
	        return curlHtml($url, $POSTFIELDS);   
	    }   
	    // 验证参数   
	    if (strlen($receipt_data)<20){   
	        $result = ['status'=>false, 'message'=>'非法参数'];   
	        return $result;   
	    }   
	    // 请求验证   
	    $html = acurl($receipt_data);   
	    $data = json_decode($html,true);   
//	    var_dump($data);
	    // 如果是沙盒数据 则验证沙盒模式   
	    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 = ['code'=>200, 'msg'=>'购买成功'];   
	    }else{   
	        $result = ['code'=>-200, 'msg' => '购买失败 status:'.$data['status'] ];  
	    }   
	    return $result;   
	} 

function curlHtml($url, $data = ''){
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_HEADER, 0);
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
    if(!empty($data)) {
        curl_setopt($ch, CURLOPT_POST, TRUE);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
    }
    $output = curl_exec($ch);
    //释放curl句柄
    curl_close($ch);
    return $output;
}
 
/**  
 * 验证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;     
        return curlHtml($url, $POSTFIELDS);   
    }   
    // 验证参数   
    if (strlen($receipt_data)<20){   
        $result = ['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 = ['status'=>true, 'message'=>'购买成功'];   
    }else{   
        $result = ['status'=>false, 'message' => '购买失败 status:'.$data['status'] ];  
    }   
    return $result;   
}  

 

参考:

https://blog.csdn.net/fangdong88/article/details/82698810?utm_source=distribute.pc_relevant.none-task

https://www.cnblogs.com/cj8988/p/10648932.html

官方文件:

https://developer.apple.com/library/archive/releasenotes/General/ValidateAppStoreReceipt/Chapters/ValidateRemotely.html#//apple_ref/doc/uid/TP40010573-CH104-SW1

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值