ホームページ  >  記事  >  バックエンド開発  >  PHP は、Apple APP でのアプリ内購入後のサーバーでの二次検証を処理します (プロジェクト エクスペリエンス)

PHP は、Apple APP でのアプリ内購入後のサーバーでの二次検証を処理します (プロジェクト エクスペリエンス)

不言
不言オリジナル
2018-04-28 09:33:567851ブラウズ

この記事の内容は、WeChat コード スキャン決済 API (国内決済) を統合する PHP プロジェクトに関するものです。これを必要とする友人に共有します。 1. Apple APP。サーバー側の検証プロセスへの支払い

1. ユーザーがアプリで購入をクリックします 2. アプリの後に支払いウィンドウが表示されます ;サーバー側の注文が正常に生成されたことを確認します

4. ユーザーが支払いを受け取ると、Apple App Store から返された支払いクーポンが送信されます。支払いバウチャーをサーバーに戻し、サーバー インターフェース

を呼び出してバウチャー

が有効かどうかを確認します。 7. アプリは、サーバー側の検証結果からユーザーの支払い結果ステータスを取得します。

: Apple Pay 製品の場合は、まず

itunes Connect

で APP アプリ内購入項目を設定する必要があります。設定後、Apple APP で Apple Pay を呼び出すときに、製品 ID が生成されます。これを Apple Store 製品 ID (product_id) パラメーターに送信します。その後、Apple Store で支払い処理が実行され、支払いが完了すると、支払いが完了したことを示す支払い伝票が APP に返されますが、通常は支払い確認のために再度独自のサーバー (マーチャントサーバー) を呼び出します。このとき、サーバー上に検証インターフェイスを作成し、バウチャーが有効かどうかを判断し、有効な場合は注文ステータスや購入した製品のステータスを適宜変更します。

2. 資格情報検証機能

        /**
	 * 验证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){
	        //小票信息
	        $secret = "XXXXXXXXXXXXXXXXXXXX";    // APP固定密钥,在itunes中获取
	        $POSTFIELDS = array("receipt-data" => $receipt_data,'password'=>$secret);
	        $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(
	            &#39;status&#39;=>false,
	            &#39;message&#39;=>&#39;非法参数&#39;
	            );
	        return $result;
	    }
	    // 请求验证
	    $html = acurl($receipt_data);
	    $data = json_decode($html,true);
	 
	    // 如果是沙盒数据 则验证沙盒模式
	    if($data[&#39;status&#39;]==&#39;21007&#39;){
	        // 请求验证
	        $html = acurl($receipt_data, 1);
	        $data = json_decode($html,true);
	        $data[&#39;sandbox&#39;] = &#39;1&#39;;
	    }
	 
	    if (isset($_GET[&#39;debug&#39;])) {
	        exit(json_encode($data));
	    }
	     
	    // 判断是否购买成功
	    if(intval($data[&#39;status&#39;])===0){
	        $result=array(
	            &#39;status&#39;=>true,
	            &#39;message&#39;=>&#39;购买成功&#39;
	            );
	    }else{
	        $result=array(
	            &#39;status&#39;=>false,
	            &#39;message&#39;=>&#39;购买失败 status:&#39;.$data[&#39;status&#39;]
	            );
	    }
	    return $result;
	}

: 検証機能には、iTunes で取得する必要があるキーがあります。 3. アプリケーションのデモ (ThinkPHP3.2 コントローラー)

4. HTTP 標準ステータス コード 3.アプリケーション 内部支払い (IAP) の詳細な説明

関連する推奨事項:

PHP 処理 WeChat SDK の傍受された写真のアップロード

以上がPHP は、Apple APP でのアプリ内購入後のサーバーでの二次検証を処理します (プロジェクト エクスペリエンス)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。