다음은 AppStore 인앱 구매의 서버 측 확인에 관한 것입니다. 결제가 완료된 후 프런트 엔드에서 해당 결제 바우처를 얻습니다. 따라서 바우처를 기반으로 실제로 결제가 이루어졌는지 확인한 후 후속 제품 기능의 비즈니스 로직을 완료해야 합니다. 하나는 프런트 엔드 자체에서 확인하는 것입니다. 다른 하나는 백엔드를 통해 검증하는 것입니다. 많은 문제가 있습니다. 일부는 백엔드를 통해 검증되므로 실제 검은 다음과 같습니다.
/** * 苹果内购Api查询接口 * Class AppleAipController * @package Pay\Controller */class AppleAipController extends Controller{ /** * @var string */ private $sandboxCurl = "https://sandbox.itunes.apple.com/verifyReceipt"; private $formalityCurl = "https://buy.itunes.apple.com/verifyReceipt"; /** * @return array */ public function send($encodeStr,$sandboxStatus=0) { $ch = curl_init(); $data['receipt-data'] =$encodeStr; $encodeStr = json_encode($data); $url = $sandboxStatus?($this->formalityCurl):($this->sandboxCurl); curl_setopt($ch, CURLOPT_URL,$url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); // post数据 curl_setopt($ch, CURLOPT_POST, 0); // post的变量 curl_setopt($ch, CURLOPT_POSTFIELDS, $encodeStr); curl_setopt($ch,CURLOPT_SSL_VERIFYPEER, false); $output = curl_exec($ch); curl_close($ch); $resut = (Array)json_decode($output,true); return $resut; } }
서명 인증 글은 클릭하시고, 토큰 글은 클릭해주세요
<?php/** * Created by PhpStorm. * User: wyb * Date: 2017/8/14 * Time: 9:57 */namespace xxxxxxxx;use Common\Tools\Attestation;use Pay\Controller\AppleAipController;use Think\Controller;/** * product苹果API内购验证 * Class CoinApiPayController */class ProductPayController extends Controller{ protected $response = ['result' => true, 'code' => 10000, 'msg' => '', 'AData' => [], 'OData' => NULL]; /** * 来源数组 * @var array */ private $targetArray = ['a_sysj', 'i_sysj', 'a_lpds', 'i_lpds','a_jjds','i_jjds']; private $testMember =['9232313'];//定好你们内部测试,人员,若人员比较多的化就做成后台管理的从数据库中取出 /** * @name 检验凭证并分发后续业务的逻辑 */ public function credentialsCheckAction() { IS_POST ||$this->returnError();//判断是否是POST $parameters =I('post.');//这里最好的相应的参数进行验证,并且使用验签校验,这里我就省略了这部分,还有下面部分最好也放在你封装或者放在你相应的模型内 $AppleAipController = new AppleAipController(); $sandboxStatus = in_array($parameters['member_id'],$thi->testMember)?1:0; $checkData = $AppleAipController->send($parameters['encodeStr'],$sandboxStatus); if($checkData['status']==0){ //校验订单号 if($checkData['receipt']['transaction_id']!=$parameters['trade_id']) { $this->returnErrorData('20012', '检验错误【01】', '21003'); } $productId = 'com.ifeimo.'.$orderInfo['product_id']; //校验商品ID if($checkData['receipt']['product_id'] != $productId){ $this->returnErrorData('20012', '检验错误【02】', '21003'); } //校验价格 $checkPrice = intval(str_replace('cxzxxxx_', '', $checkData['receipt']['product_id'])); if($checkPrice!=$orderInfo['price']){ $this->returnErrorData('20012', '检验错误【03】', '21003'); } $result = self::notifyAdd($orderInfo); $this->response['msg'] = '支付成功'; $status = $checkData['status']; }else{ $status = $checkData['status']; $this->response['status'] = $status; $this->response['result'] = false; $this->response['msg'] = '待支付'; } $this->response['order'] = $orderInfo; $this->response['encodeStatus'] = $status; $this->ajaxReturn($this->response);//返回数据给前端 } /** * 整合异步发放 * @param $order * @param $time * @return int */ private function notifyAdd($order) { //这里写你相应的分发业务 } /** * 错误返回 * @param string $msg 错误提示信息,默认‘请求处理失败’ */ private function returnErrorData($code = '20000', $msg = '请求处理失败',$status='21003'){ $this->response['result'] = false; $this->response['status'] = $status; $this->response['code'] = $code; $this->response['msg'] = $msg; $this->ajaxReturn($this->response); } }
tp의 글쓰기 방법이 포함될 수 있기 때문에, 분할에 도움이 필요하시면 제 블로그를 통해 제 그룹에 가입하시면 제가 해결해드릴 수 있습니다.
관련 추천:
위 내용은 PHP는 Apple API 인앱 구매 바우처의 확인 예제 코드를 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!