/**
* 驗證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;
// dump($url);die;
// $url = $url_sandbox;
//簡單的curl
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $POSTFIELDS);
curl_setopt ($ch, CURLOPT_SSL_VERIFYPEER, 0); //這兩行一定要加,不加會報SSL 錯誤
curl_setopt ($ch, CURLOPT_SSL_VERIFYHOST, 0);
$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);
// dump($data);die;
// 如果是沙盒數據 則驗證沙盒模式
if($data['status']=='21007'){
// 請求驗證
$html = acurl($receipt_data, 1);
$data = json_decode($html,true);
$data['sandbox'] = '1';
// dump($data);die;
}
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 $data;
}