iPhone/iPad的IAP防破解的代码怎么写-创新互联

本篇文章为大家展示了iPhone/iPad的IAP防破解的代码怎么写,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

创新互联一直通过网站建设和网站营销帮助企业获得更多客户资源。 以"深度挖掘,量身打造,注重实效"的一站式服务,以成都网站制作、成都网站建设、外贸营销网站建设、移动互联产品、成都全网营销服务为核心业务。十余年网站制作的经验,使用新网站建设技术,全新开发出的标准网站,不但价格便宜而且实用、灵活,特别适合中小公司网站制作。网站管理系统简单易用,维护方便,您可以完全操作网站资料,是中小公司快速网站建设的选择。

现在IAP破解很严重,让我等本来就收入不多的个人开发者更是雪上加霜。破解原理在此就不作过多讲解了。正所谓魔高一尺,道高一丈,各种防IAP破解的方法出来了,其它比较有效的是和Apple服务器二次验证。意思就是拿到购买成功的数据再次发送到Apple服务器去验证此次购买是否真实有效。但如果你是在iPhone/iPad上和Apple服务器做这个二次验证,也是有可能被破解的(有Developer测试后确定是能破解,这个我没测试过)。所以这个二次验证好放在自己的服务器上(VPS和虚拟主机即可,因为我的是VPS,所以下文以VPS指代)。由于iPhone/iPad和VPS之间的验证协议完全由你自己定,所以这样基本上能做到万无一失!

约定:

1. VPS端程序用的是PHP

2. iPhone/iPad端代码采用了第三方库:ASIHTTPRequest, GMTBase64

大概步骤如下:

1. iPhone/iPad向Apple服务器发送购买请求

2. Apple服务器返回购买成功的receipt

3. iPhone/iPad将收到的receipt用Base64编码后发送到自己的VPS

4. 自己的VPS的PHP程序收到receipt后向Apple服务器发送二次验证,验证该receipt是否真实有效

5. Apple回复验证结果

6. 得到结果,你就可以随意了~~

iPhone/iPad端代码

  1. - (BOOL) verifyReceipt:(NSData*)receipt

  2. {

  3.     NSURL *url = [NSURL URLWithString:[NSString stringWithFormat:@"%@/verifyiapreceipt.php", SERVER_DOMAIN]];

  4.     ASIFormDataRequest *request = [ASIFormDataRequest requestWithURL:url];

  5.     [request setPostValue:[GTMBase64 stringByEncodingData:receipt] forKey:@"receipt"];

  6. #ifdef TEST_SANDBOX

  7.     [request setPostValue:@"1" forKey:@"sandbox"];

  8. #else

  9.     [request setPostValue:@"0" forKey:@"sandbox"];

  10. #endif


  11.     [request startSynchronous];

  12.     NSError *err = [request error];

  13.     if (err)

  14.     {

  15.         return  NO;

  16.     }


  17.     if (处理reqquest,如果是验证成功)

  18.         return YES;

  19.     return NO;

  20. }

VPS端代码(PHP)

  1.     function getReceiptData($receipt, $isSandbox = false)

  2.     {

  3.         if ($isSandbox) {

  4.             $endpoint = 'https://sandbox.itunes.apple.com/verifyReceipt';


  5.         }

  6.         else {

  7.             $endpoint = 'https://buy.itunes.apple.com/verifyReceipt';


  8.         }


  9.         $postData = json_encode(

  10.             array('receipt-data' => $receipt)

  11.         );


  12.         $ch = curl_init($endpoint);

  13.         curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

  14.         curl_setopt($ch, CURLOPT_POST, true);

  15.         curl_setopt($ch, CURLOPT_POSTFIELDS, $postData);


  16.         $response = curl_exec($ch);

  17.         $errno    = curl_errno($ch);

  18.         $errmsg   = curl_error($ch);

  19.         curl_close($ch);


  20.         if ($errno != 0) {

  21.             throw new Exception($errmsg, $errno);

  22.         }


  23.         $data = json_decode($response);


  24.         if (!is_object($data)) {

  25.             throw new Exception('Invalid response data');

  26.         }


  27.         if (!isset($data->status) || $data->status != 0) {

  28.             throw new Exception('Invalid receipt');

  29.         }


  30.         return array(

  31.             'quantity'       =>  $data->receipt->quantity,

  32.             'product_id'     =>  $data->receipt->product_id,

  33.             'transaction_id' =>  $data->receipt->transaction_id,

  34.             'purchase_date'  =>  $data->receipt->purchase_date,

  35.             'app_item_id'    =>  $data->receipt->app_item_id,

  36.             'bid'            =>  $data->receipt->bid,

  37.             'bvrs'           =>  $data->receipt->bvrs

  38.         );

  39.     }


  40.     $receipt   = $_REQUEST['receipt'];

  41.     $isSandbox = (bool) $_REQUEST['sandbox'];


  42.     try {

  43.         $info = getReceiptData($receipt, $isSandbox);


  44.         //验证购买有效

  45.     }

  46.     catch (Exception $ex) {

  47.         //验证购买无效

  48.     }

  49. ?>

这样就完成了。这种方式的缺点是相比正常流程下要慢一点,因为要经过自己的VPS,但在使用过程中感觉不是太明显。

上述内容就是iPhone/iPad的IAP防破解的代码怎么写,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


当前标题:iPhone/iPad的IAP防破解的代码怎么写-创新互联
文章来源:http://pwwzsj.com/article/gccig.html