- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我一直在寻找一种方法来检测在我的应用程序中使用 IAPCracker 的人。
最近我发现这篇有用的帖子 How to detect “LocallAPStore" - new iap cracker并用它来保护我的一些应用内购买。
现在我找到了应用内破解的新来源-...你知道的。所以我安装了这个名为 IAPFree 的新调整,这是一种破解 IAP 的新方法。我在一些应用程序和我自己的应用程序上对其进行了测试并且它运行良好,这并不好!
我尝试用与 IAPCracker 相同的方式检测它:
if ([[NSFileManager defaultManager] fileExistsAtPath:@"/Library/MobileSubstrate/DynamicLibraries/iap.dylib"]){
NSLog(@"IAP Cracker detected");
}
但是不幸的是文件名被改成了“iapfree.core.dylib”(我打开了IFile,在同一个目录下找到了这个文件)。
现在我想我可以简单地替换目录。但是,它不起作用!我用这段代码以某种方式检测到它:
if ([[NSFileManager defaultManager] fileExistsAtPath:@"/Library/MobileSubstrate/DynamicLibraries/iapfree.core.dylib"]){
NSLog(@"IAPfree detected");
}else{
NSLog(@"No IAPFree found");
}
我认为这是一个随机错误,我用同一目录中的其他文件进行了尝试。他们确实奏效了!
我不知道这个文件有什么问题。我认为这可能是“.core.”引起的,但实际上我不知道。
你知道如何解决问题或用其他方式检测吗?
最佳答案
解决此问题的最佳方法(也是“Apple 批准”的唯一方法)是使用外部服务器检查应用内购买收据,而不是破解程序的存在!有很多第 3 方服务可以轻松做到这一点,有些甚至是免费的。
作为替代方案,您可以只在本地检查收据,如图所示 here和 here (完全公开,这是我的博客;))。它有一些优势(更简单,即使验证服务器离线或无法访问也能正常工作)但当然新的破解系统可能会欺骗它。
这里有一段代码:当你检查 paymentQueue(inApp 协议(protocol)的回调)时,你可以这样做:
- (void)paymentQueue:(SKPaymentQueue *)queue updatedTransactions:(NSArray *)transactions
{
for (SKPaymentTransaction *transaction in transactions)
{
switch (transaction.transactionState)
{
case SKPaymentTransactionStatePurchased:
case SKPaymentTransactionStateRestored:
{
[self checkReceipt:[_productIdentifierList objectAtIndex:0] transazione:transaction];
[self finishPaymentTransaction:transaction];
}
break;
case SKPaymentTransactionStateFailed:
{
[UIView msgBox:@"Transaction Error" title:@"Errore"];
[self finishPaymentTransaction:transaction];
}
break;
default:
break;
}
}
}
- (void) checkReceipt:(SKProduct *)prodotto transazione:(SKPaymentTransaction *)transaction
{
NSString*ricevuta = [[NSString alloc] initWithData:transaction.transactionReceipt encoding:NSUTF8StringEncoding];
NSRange hackTest = [transaction.transactionIdentifier rangeOfString:@"com.urus.iap"]; // ok if this not found
NSRange hackTest2 = [transaction.transactionIdentifier rangeOfString:@"PUT HERE YOUR INAPP ID"]; // TODO: PUT HERE YOUR INAPP ID
if (hackTest.location == NSNotFound && hackTest2.location == NSNotFound)
{
// it pass the local test: receipt is probably good
}
else
{
// invalid receipt, fake for sure, cancel buying...
}
}
请注意,您必须将您的 inApp 代码放入“hackTest2”检查中:因此,如果您有多个产品,您可能会形成一个循环...
关于ios - 如何检测 IAPFree 和 IAP Cracker,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15248724/
我正在用 C++ 编写一个软件,它针对的是一个软件在传统上被严重破解(或至少试图被破解)的市场。我意识到没有什么是可以完全保护的,但是我觉得尝试是个好主意,而且我认为我所处情况的一些细节可能会有所帮助
我发现许多用户使用所谓的“IAP 破解器”而不是在应用内购买 (IAP) 中购买商品。我还了解到 Zynga Poker 和 Pokerist 已经检测到 IAP 破解程序并防止伪造 IAP。我想检测
我正在尝试让这个影子文件破解器正常工作,但我一直收到 TypeError: integer required. 我确定这是我使用 bytearray 函数的方式。我尝试用 bytearray 为“wo
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 7 年前。 Improve this qu
我正在尝试找到一种解决方案来保护记住我的功能。将使用 Cookie。 function enc($string) { $slat = "%32!@x"; //can be auto-genera
我一直在寻找一种方法来检测在我的应用程序中使用 IAPCracker 的人。 最近我发现这篇有用的帖子 How to detect “LocallAPStore" - new iap cracker并
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我是一名优秀的程序员,十分优秀!