`
mmdev
  • 浏览: 13328926 次
  • 性别: Icon_minigender_1
  • 来自: 大连
文章分类
社区版块
存档分类
最新评论

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

 
阅读更多

本站文章均为李华明Himi原创,转载务必在明显处注明:
转载自【黑米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];
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防护的童鞋有所帮助!

分享到:
评论

相关推荐

    unity 嵌入 百度Frontia分享,ios-iap

    在Unity游戏开发中,将百度Frontia嵌入到iOS应用中是为了实现社交分享功能,同时结合iOS的In-App Purchase(iap)服务,为用户提供在游戏内的购买体验。以下是关于这些知识点的详细说明: 1. **Unity引擎**: ...

    go-iap通过AppStore、GooglePlayStore、AmazonAppStore和华为HMS验证购买收据 .zip

    去iap go-iap 通过 AppStore、GooglePlayStore 或 Amazon AppStore 验证购买收据。当前 API 文档应用商店AppStore 服务器 APIGooglePlay亚马逊应用商店:华为HMS安装go get github....

    stm32-iap-uart-boot-master.zip_IAP_STM32 IAP_STM32升级程序_bootload

    STM32 IAP(In-Application Programming)是意法半导体STM32微控制器系列中的一种固件升级技术,允许在不使用外部编程器的情况下更新应用程序。UART Bootloader是一种常见的IAP实现方式,通过串行通信接口(通用异步...

    stm32-iap-ymodem-client-c#_c#iap升级demo_IAP_iap客户端_Ymodem_

    在本项目"stm32-iap-ymodem-client-c#_c#iap升级demo_IAP_iap客户端_Ymodem_"中,我们将关注如何通过C#实现一个STM32的IAP升级客户端,以及使用Ymodem协议来传输文件。 一、STM32 IAP原理 IAP是嵌入式系统中常用的...

    STM32\整体资料\BHS-STM32+实验39-IAP远程更新用户程序.rar

    在本资源包“BHS-STM32+实验39-IAP远程更新用户程序.rar”中,主要介绍的是如何利用In-Application Programming(IAP)技术在STM32上实现远程更新用户程序的功能。IAP是一种允许程序在运行过程中修改自身的存储器...

    go-iap:go-iap通过AppStore,GooglePlayStore,AmazonAppStore和Huawei HMS验证购买收据

    闲聊 go-iap通过AppStore,GooglePlayStore或Amazon AppStore验证购买​​收据。 当前的API文档: 应用商店: GooglePlay: 亚马逊应用商店: 华为HMS:安装go get github....

    Python库 | itunes-iap-2.5.0.tar.gz

    IAP是苹果在其iOS和Mac App Store中提供的一种服务,允许用户在应用程序内部购买额外的内容、功能或服务,而不必离开应用程序本身。对于开发者来说,IAP是一个重要的收入来源,同时也为用户提供了一种便捷的付费方式...

    电子-IAP.rar

    在嵌入式系统开发中,IAP是一种重要的程序更新方式,它允许用户在不拔掉电源的情况下更新固件,极大地提高了产品的可维护性和灵活性。 STM32是意法半导体(STMicroelectronics)推出的基于ARM Cortex-M内核的微控制...

    stm8-IAP.rar_IAP例程_stm8 升级_stm8-IAP_stm8s iap_产品

    STM8的IAP功能使得固件更新变得更加便捷,用户可以通过串口或者SPI等通信接口上传新的固件,然后由IAP程序将新固件写入到闪存中。这样可以避免在产品部署后由于软件缺陷而需要更换硬件的问题。 2. **IAP相关代码**...

    react-native-iap:应用内购买的react-native本机模块

    公告 最近, react-native-iap模块维护... 同样,实现客户端只是硬币的一面,您必须实现服务器端才能验证收据(正确完成收据可能是最耗时的部分)。 如果您正在寻找比react-native-iap更进一步的模块,我们建议您使用

    STC-USER-IAP-ISP-DEMO(基于IAP15F2K61S2的公开发布版本)-(2014-1-7).rar

    2. "用户代码范例":这部分可能包含了一些实际的C代码或汇编代码示例,展示如何在用户应用程序中集成IAP功能,比如如何调用IAP子程序进行内部存储器的编程。 3. "STC_IAP_ISP监控程序":这是一个监控程序,用于监控...

    x-cube-iap-usart

    STMicroelectronics针对Cube(HAL)提供的通过URART/UART实现IAP,适用于STM32系列MCU,无需再设置BOOT引脚,仅需一个GPIO设置POR后执行IAP还是APP,分享给坛友,该程序包也可从ST官网... 同时附带该程序包的APP.Note...

    9.31-IAP-iOS内购功能的具体实现和测试

    在iOS应用开发中,内购(In-App Purchase,简称IAP)是一种常见的商业模式,允许用户在应用程序内部购买额外的功能、服务或虚拟商品。本文将深入探讨如何在iOS平台上实现IAP功能,并进行相应的测试。 首先,理解IAP...

    ymodem-IAP.rar

    IAP是一种在应用中更新程序的技术,允许用户在设备运行时更新其内部的闪存,而无需外部编程器。 描述中提到,这个项目是一个自编写的STM32 IAP上位机软件,它通过串口通信与单片机交互,实现了固件的烧录功能。这...

    智能交通灯-iap15w4k

    智能交通灯-iap15w4k项目是一个创新的交通信号控制方案,它在大学挑战杯竞赛中获得了新疆三等奖,体现了其技术先进性和实用性。该项目的核心是使用了iap15w4k58s4型号的单片机进行设计与开发。这个单片机是一种微...

    LASG-IAP 气候系统海洋模式(LICOM1.0)参考手册

    LASG-IAP 气候系统海洋模式(LICOM1.0)参考手册 &lt;br&gt;请大家自觉保护版权

    LPC17XX-IAP存储测试代码

    【LPC17XX-IAP存储测试代码】是针对NXP公司生产的LPC1758和LPC1768微控制器进行的在应用编程(In-Application Programming, 简称IAP)功能的测试代码。这些微控制器属于Cortex-M3内核的LPC系列,广泛应用在嵌入式...

    STM32-iap-usart.7z

    STM32-iap-usart项目是一个由STM(意法半导体)官方提供的串行通信Bootloader实现,它基于Ymodem协议。这个项目旨在为开发者提供一个便捷的方式,通过串口进行固件更新,无需借助额外的编程器。下面将详细阐述STM32...

Global site tag (gtag.js) - Google Analytics