【iOS-iap防护】验证用户付费收据!拒绝iap Cracker!!让iphone越狱用户无从下手!!!

2023-11-05

转载自【黑米GameDev街区】 原文链接: http://www.himigame.com/iphone-cocos2d/673.html

对于iOS的应用安全这块主要有两块是我们开发者可以避免的,一个是存储数据加密,这个在上一篇文章Himi介绍了base64加密算法;另外一个就是付费产品防护!那么本篇Himi来分享如何防护越狱用户的iap Cracker!

对于iap Cracker这个插件,Himi简单介绍下!

iap Cracker可以说是iOS越狱用户的终极利器阿,当今app Store的所有内置收费的游戏,基本使用此插件进行秒购买无压力!(对于那些收费下载的游戏,对于越狱用户来说,安装个XX助手<你懂得~>就可以免费体验app store的所有游戏,不管你下载收费还是内置收费!)

iap Cracker能绕过appstore的付费流程,其方式是当用户点击付费产品进行购买后,iap Cracker模拟返回一个购买成功的消息(无需联网,说白了,连post 数据给App store都没有!),然后我们应用中收到这个“假的”交易成功的消息直接给用户加钱,加装备,加各种….

OK,对于iap Cracker就不再多介绍了,下面Himi来分享如何防护iap Cracker吧;

对于越狱用户使用付费破解插件进行付费这个问题,其实Apple并没有不管,而是已经在文档中清晰的说明,只是很多童鞋并没有发现,如下截图:

apple提示开发者付费要进行验证付费收据! 原文apple dev官方文档连接:

https://developer.apple.com/library/ios/#documentation/NetworkingInternet/Conceptual/StoreKitGuide…

  下面Himi就详细讲解如何在我们付费流程中加入iap防护,步骤如下:

1. 首先将 json类库和NSData+Base64类导入你的项目中,下载:

  json_base.rar (105 字节, 14 次)

2. 然后将Himi封装的如下函数拷贝到你付费代码所在的类中:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
.h中:
-( BOOL )putStringToItunes:(NSData*)iapData;
 
.m中:
 
#import "NSData+Base64.h"
#import "NSString+SBJSON.h"
#import "JSON.h"
 
-( BOOL )putStringToItunes:(NSData*)iapData{ //用户购成功的transactionReceipt
 
     NSString*encodingStr = [iapData base64EncodedString];
 
     NSString *URL=@ "https://sandbox.itunes.apple.com/verifyReceipt" ;
     NSMutableURLRequest *request = [[NSMutableURLRequest alloc] init]; // autorelease];
     [request setURL:[NSURL URLWithString:URL]];
     [request setHTTPMethod:@ "POST" ];
     //设置contentType
     [request addValue:@ "application/json" forHTTPHeaderField:@ "Content-Type" ];
     //设置Content-Length
     [request setValue:[NSString stringWithFormat:@ "%d" , [encodingStr length]] forHTTPHeaderField:@ "Content-Length" ]; 
 
     NSDictionary* body = [NSDictionary dictionaryWithObjectsAndKeys:encodingStr, @ "receipt-data" , nil];
     SBJsonWriter *writer = [SBJsonWriter new ];
     [request setHTTPBody:[[writer stringWithObject:body] dataUsingEncoding:NSASCIIStringEncoding allowLossyConversion:YES]];
     NSHTTPURLResponse *urlResponse=nil;
     NSError *errorr=nil;
     NSData *receivedData = [NSURLConnection sendSynchronousRequest:request
                                                  returningResponse:&urlResponse
                                                              error:&errorr];
 
     //解析
     NSString *results=[[NSString alloc]initWithBytes:[receivedData bytes] length:[receivedData length] encoding:NSUTF8StringEncoding];
     CCLOG(@ "-Himi-  %@" ,results);
     NSDictionary*dic = [results JSONValue];
     if ([[dic objectForKey:@ "status" ] intValue]==0){ //注意,status=@"0" 是验证收据成功
         return true ;
     }
     return false ;
}

接着说下此方法的使用,一般付费代码中,童鞋们肯定会有如下函数:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
- ( void )paymentQueue:(SKPaymentQueue *)queue updatedTransactions:(NSArray *)transactions //交易结果
{
     for (SKPaymentTransaction *transaction in transactions)
     {
         switch (transaction.transactionState)
         {
             case SKPaymentTransactionStatePurchased: //交易完成
                  if ([self putStringToItunes:transaction.transactionReceipt]){
                      //这里给用户添加钱阿,装备阿什么的
                  }
                    break ;
              ......代码省略
          }
      }
}

上面这个函数当获取交易成功的消息都会进入到SKPaymentTransactionStatePurchased这个case中(不管是iap cracker模拟的还是appstore真的反馈的消息), 那么我们一般不做iap防护情况下,会直接在此case中给用户添加金币阿,什么的! 但是如上所说因为iap cracker也会模拟返回交易成功的消息,也会进入到这个case中,因此我们在此与appstore再次进行一次收据验证!

另外说一点当交易完成时appstore传回来的transaction(SKPaymentTransaction)类中的transactionReceipt属性里包含AppStore返回经过签名的收据信息!OK,我们要的就是这个收据并将此收据post给appstore 的server进行收据验证,所以在SKPaymentTransactionStatePurchased这个交易成功的case中再调用Himi封装的函数if([self putStringToItunes:transaction.transactionReceipt]){} 进行再次确认下购买是否付费流程正确!

那么下面详细说下Himi封装的这个putStringToItunes函数:

此函数中,首先我们将传入的收据data类型变量进行base64转换成string类型,然后将此收据以json的形式发送给appstore进行验证!这里注意!一定要以json形式发送,否则appstore server端不识别!

最后再次利用json对appstore server返回的字段(json数据)进行解析,我们只需要解析出 status 这个key的value即可!

当appstore验证收据正确时我们解析出来的 status 这个key的value值为0(零)!

下面是appstore返回json数据的两种形式:

1. 收据无效的情况:

1
{ "status" :21002, "exception" : "java.lang.NullPointerException" }

2.收据正确的情况,如下图(点击放大):


最后大家需要注意的一点是,Himi封装的函数中post的地址这里要记得发布的时候修改!

      因为当你沙盒测试的时候地址是:https://sandbox.itunes.apple.com/verifyReceipt

      但是正式发布后post的地址应该是:  https://buy.itunes.apple.com/verifyReceipt

千万不要发布应用的时候别忘记修改这里!

OK,本篇就介绍到这里,希望对还没有做iap防护的童鞋有所帮助!

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

【iOS-iap防护】验证用户付费收据!拒绝iap Cracker!!让iphone越狱用户无从下手!!! 的相关文章

随机推荐

  • 精品微信小程序ssm校友录网站+后台管理系统

    博主介绍 在职Java研发工程师 专注于程序设计 源码分享 技术交流 专注于Java技术领域和毕业设计 温馨提示 文末有 CSDN 平台官方提供的老师 Wechat QQ 名片 项目名称 精品微信小程序ssm校友录网站 后台管理系统 演示视
  • 【网络编程】传输层协议——UDP协议

    文章目录 一 传输层的意义 二 端口号 2 1 五元组标识一个通信 2 2 端口号范围划分 2 3 知名端口号 2 4 绑定端口号数目问题 2 5 pidof netstat命令 三 UDP协议 3 1 UDP协议格式 3 2 如何理解报头
  • TortoiseGit如何迁移项目地址

    大家工作中可能会遇到项目迁服务器 那么在以前老服务器上的git项目也需要迁到新服务器 如果大家使用TortoiseGit 那么该如何迁移呢 很简单 一 首先在新服务器git上建个项目 然后把项目地址复制下来 二 在本地项目里找到 git文件
  • 你需要知道的企业网页制作流程

    企业网页制作是企业建立线上形象和宣传的重要手段之一 它不仅可以提高企业的品牌知名度 还可以扩大企业的影响力和拓展客户群 下面 我们将介绍一些企业网页制作的基本流程和技巧 并结合一个案例来详细解析 企业网页制作的基本流程可以分为以下几个步骤
  • Android自定义View(三) Scroller与平滑滚动

    目录 一 什么是Scroller 二 认识scrollTo和scrollBy方法 2 1 scrollTo scrollBy对View内容的影响 2 2 思考为什么移动负数距离会向坐标正方向移动 2 3 scrollTo scrollBy对
  • 预训练网络的模型微调方法

    是什么 神经网络需要数据来训练 从数据中获得信息 进而转化成相应的权重 这些权重能够被提取出来 迁移到其他的神经网络中 迁移学习 通过使用之前在大数据集上经过训练的预训练模型 我们可以直接使用相应的结构和权重 将他们应用在我们正在面对的问题
  • python字符串去重_Python对字符串实现去重操作的方法示例

    前言 最近在工作经常会碰到对字符串进行去重操作 下面就给大家列出用Python如何处理的 话不多说了 来一起看看详细的介绍吧 比如说 要拿下面的字符传去掉重复的AA A B C S AA BB EE DD AA A B C CC A B C
  • chatgpt赋能python:用Python根据IP地址查找具体地址:一个实用的SEO技巧

    用Python根据IP地址查找具体地址 一个实用的SEO技巧 在数字化时代 IP地址是一个重要的数字标识符 使用IP地址来发现目标受众的位置是网络营销和搜索引擎优化策略的重要组成部分 在本文中 我们将介绍用Python编程语言根据IP地址查
  • 前端页面无法渲染两个Google Translate插件

    在w3c官方给出的demo里尝试了一下 无论添加几个Google Translate标签 始终只会渲染首个Google Translate标签 需要在script标签里添加一下代码 即可解决
  • python人工智能项目开发实例-人工智能学习路线图,整理近200个实战案例与项目...

    Created by 唐宇迪 人工智能实战就业 面试 学习路线图 这个项目是干什么的 整理这个项目的初衷是方便同学们快速开启人工智能自学计划 在学习过程中少走弯路用最快的效率入门Ai并开始实战项目 提供了近200个Ai实战案例和项目 这些并
  • geth指定版本安装

    下载源码 cd usr local git clone https github com ethereum go ethereum git 或者 mirror git clone https ghproxy com https github
  • TRC-20合约

    pragma solidity 0 5 0 import IERC20 sol import SafeMath sol dev Implementation of the IERC20 interface This implementati
  • List从服务器取文件名乱码,急用!!!为什么list程序输出会乱码??

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 window 15 2 78 23 textbackground LIGHTGREEN textcolor LIGHTMAGENTA clrscr gotoxy 1 3 printf Delet
  • Android学习笔记(一)——Activity基础知识

    Activity基础知识 Activity 活动 是一种可以包含用户界面的组件 一个应用程序可以包含多个活动 Android项目中逻辑和试图分离 每个活动最好对应一个布局 布局是用来显示界面内容的 Activity和布局文件如何关联起来 在
  • PyTorch基础-交叉熵函数mnist数据集识别-04

    交叉熵 代码 import numpy as np import torch from torch import nn optim from torch autograd import Variable from torchvision i
  • Spring框架详解(三)

    一 代理模式 代理模式 为一个对象提供一个替身 以控制对这个对象的访问 即通过代理对象访问目标对象 这样做的好处就是 可以在目标对象实现的基础上 增强额外的功能操作 即扩展目标对象的功能 被代理对象可以是远程对象 创建开销大的对象或者是需要
  • 批量上传图片

    前端使用jQuery完成图片的上传 后端使用Java接收图片文件 具体实现步骤 使用HTML和CSS进行页面的布局 并引入jQuery库 使用三个input标签 类型均为type file 的标签 并命名好相对应的id 这个id可以命名的有
  • 数睿通2.0功能发布—集成Doris、数仓动态配置、质量任务完善、接入速度优化

    文章目录 引言 集成 Doris 数仓动态配置 质量任务完善 接入速度优化 结语 引言 数睿通 2 0 数据中台迎来了 6 月份的更新 本次更新集成了 Doris 数据库 可用于数据集成 数据开发等模块 过去数仓使用的是 TiDB 新版本可
  • python获取浏览器 cookies

    python 获取浏览器 cookie代码 import browser cookie3 dict1 browser cookie3 chrome domain name baidu com print dict1 s for u in d
  • 【iOS-iap防护】验证用户付费收据!拒绝iap Cracker!!让iphone越狱用户无从下手!!!

    转载自 黑米GameDev街区 原文链接 http www himigame com iphone cocos2d 673 html 对于iOS的应用安全这块主要有两块是我们开发者可以避免的 一个是存储数据加密 这个在上一篇文章Himi介绍