苹果支付 PHP 服务端处理

苹果支付 PHP 服务端处理,第1张

概述因为上周末连续加班2天(产品非要周一上线新版本),因此断更公众号一段时间,今天继续补上。 之前有了微信和支付宝支付后,产品要加上苹果支付,于是有了这篇文章。一、ios端流程itunnes相关配置一.在itunnes上配置相关信息资料首先需要配置一些前提条件,详细步骤如下1.进入itunn

因为上周末连续加班 2 天(产品非要周一上线新版本),因此断更公众号一段时间,今天继续补上。

 

之前有了微信和支付宝支付后,产品要加上苹果支付,于是有了这篇文章。

一、ios 端流程

itunnes 相关配置

一.在itunnes 上配置相关信息资料

首先需要配置一些前提条件,详细步骤如下

1.进入itunnes选择协议,税务银行业务

2.完善资料信息,主要有3项(联系人,银行信息,税务信息)
3.完善联系人信息,一般填申请开发者账号人员的信息,可以修改

4.完善银行信息 需要银行支付号(就是开户银行的一个标识),yhk持有人名字

 

 

5.完善税务信息

6.以下默认选择no

7.确认界面,下图可能不太对,当时我是上下2个界面,第四项要上下一致才行

 

上面资料完善后换需要配置相关虚拟物品

1.选择对应应用
2.选择功能,我们添加一个app内购项目。
3.选择类型
a.可消费的产品 使用一次,之后就会耗尽,必须再次购买
b.非消耗品 一次购买的产品,不会到期,这种物品一般来说要使用恢复购买的功能
c.自动订阅类内购 这种物品会在一段时间内自动订阅
d.非自动订阅 如一次订阅一年的服务会员
4.提交一个屏幕快照(注意尺寸大小一般是用到内购的界面)。
三.接下来需要添加沙箱测试账号,此账号是在测试环境测试内购流程的
1.点击进入用户和职能界面
2.选择沙盒技术测试员
3.填写测试员信息(填写未被其他开发者使用的邮箱)
内购实现流程

 

 

本地处理

程序通过bundle存储的pList文件得到产品标识符的列表。

程序向App Store发送请求,得到产品的信息。

App Store返回产品信息。

程序把返回的产品信息显示给用户(App的store界面)

用户选择某个产品

程序向App Store发送支付请求

App Store处理支付请求并返回交易完成信息。

App获取信息并提供内容给用户。
依靠服务器处理 (一般需要一个订单号对应相应的凭证信息)

程序向服务器发送请求,获得一份产品列表。

服务器返回包含产品标识符的列表。

程序向App Store发送请求,得到产品的信息。

App Store返回产品信息。

程序把返回的产品信息显示给用户(App的store界面)

用户选择某个产品 生成订单号

程序向App Store发送支付请求

App Store处理支付请求并返回交易完成信息。

程序从信息中获得数据,(目前是订单号和凭证)并发送至服务器。

服务器将数据发给App Store来验证该交易的有效性。(主要是凭证的验证)具体可以查看https://developer.apple.com/library/content/releasenotes/General/ValIDateAppStoreReceipt/Introduction.HTML#//apple_ref/doc/uID/TP40010573

App Store对收到的数据进行解析,返回该数据和说明其是否有效的标识。

服务器读取返回的数据,确定用户购买的内容。

服务器确认成功后告诉客户端。
漏单问题 需要注意的是因为订单是和服务器保持同步的,但是购买流程在客户端,所有因为网络等问题会出现,漏单的问题,所以每次购买成功后需要本地保存一份凭证,只有当服务端验证通过后才从本地删掉,另外换需要在程序启动后在合适的时机检测是否有未处理的凭证,如果有需要给服务端验证。

相关链接 https://developer.apple.com/in-app-purchase/
官方demo
https://developer.apple.com/library/content/samplecode/sc1991/Introduction/Intro.HTML#//apple_ref/doc/uID/DTS40014726

参考 http://allluckly.cn/ios支付/iOS开发2015年最新内购教程

二、PHP端处理

 

说明: 1、根据前端传过来的购买凭证,服务器发请求去苹果验证,验证凭证是否有效。

2、如果凭证有效,还有验证凭证是否被验证过,凭证只能成功被验证一次(防止伪造请求刷单,比如用一次成功的凭证和多次失败的订单号来构造请求)。

3、通过苹果返回的数据,检查产品ID是否匹配。 上面三个验证都通过了才认为有效、成功的购买。

客户端要有失败重试机制,防止网络断掉或者其他异常导致验证请求发送失败,进而导致丢单现象(用户的钱花了,但是在我们平台上并没有购买/充值成功)

传递参数

{

"voucher":2 //凭证号

"order_ID": 1, // 订单ID

}

返回

{

"code":200,

"msg":"success,

"data":{

"voucher":100 //凭证号,

"order_ID": 333 //订单号

}

}

 

// 苹果充值验证 这里只是处理类的几个方法

   public function anyAppLeverify(Request $request)

   {

       $userID = $request->input('user_ID',0);

 

       $verifyUrlSandBox = 'https://sandBox.itunes.apple.com/verifyReceipt'; // 沙盒测试

       $verifyUrl = 'https://buy.itunes.apple.com/verifyReceipt'; // 正式服务

 

       $voucher = $request->input('voucher', '');

       $orderID = $request->input('order_ID', '1');

       if (empty($voucher)) {

           return [ 'code' => 10086, 'msg' => '凭证不能为空'];

       }

 

       // 验证凭证是否有效https://developer.apple.com/library/content/releasenotes/General/ValIDateAppStoreReceipt/Chapters/ValIDateRemotely.HTML#//apple_ref/doc/uID/TP40010573-CH104-SW1

 

       $purchaseInfo = $this->doAppLeverify($verifyUrl, $voucher);

       if($purchaseInfo->status == 21007){ //走沙盒验证 测试环境

           $purchaseInfo = $this->doAppLeverify($verifyUrlSandBox, $voucher);

       }

$order = $purchaseInfo ->receipt->in_app;//所有的订单的信息

if ($purchaseInfo->status != 0) {

  return ['code' => 400, 'msg' => '购买凭证验证失败'];//更新订单状态

}

}

protected function doAppLeverify($verificationUrl, $receipt){

       $postData = ['receipt-data' => $receipt];

       $postData = Json_encode($postData);

       $purchaseInfoStr = Common::CurlRequest($verificationUrl, $postData);

       $purchaseInfo = Json_decode($purchaseInfoStr);

 

       return $purchaseInfo;

   }

public static function CurlRequest($url, $data = '', $timeOut = 60)

   {

       $curl = curl_init();

       curl_setopt($curl, CURLOPT_URL, $url);

       curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0);

       curl_setopt($curl, CURLOPT_header, 0);

       curl_setopt($curl, CURLOPT_autoREFERER, 1);

       curl_setopt($curl, CURLOPT_POST, 1);

       curl_setopt($curl, CURLOPT_POSTFIELDS, $data);

       curl_setopt($curl, CURLOPT_TIMEOUT, $timeOut);

       curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);

 

       $time = microtime(true);

       $resultData = curl_exec($curl);

       if (($time = microtime(true) - $time) > 1) {

           Log::warning("Slow curl \"POST {$url}\".", ['time' => number_format($time, 2)]);

       }

 

       if (curl_errno($curl)) {

           Log::warning("Curl Failed \"POST {$url}\", " . curl_error($curl), ['time' => number_format($time, 2)]);

 

           curl_close($curl);

           return false;

       } else {

           curl_close($curl);

 

           return $resultData;

       }

   }


简单总结起来就是:支付时生成一个订单ID返回给 ios ,然后 ios 调用苹果支付产生一个凭证号,之后将支付成功后的订单和凭证号传递给服务端校验是否支付成功。

 

 

总结

以上是内存溢出为你收集整理的苹果支付 PHP 服务端处理全部内容,希望文章能够帮你解决苹果支付 PHP 服务端处理所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1000324.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存