Android应用内购买检查买家离线

我已经在我的应用程序中使用计费服务实现应用程序购买(托管),当用户想要购买物品时,即使用户已经购买了物品,他也会提出需要互联网的购买请求.所以为了方便用户,我这样做,如果用户购买了该项目,那么一个值将保存在共享的首选项中.当用户点击该特定项目时,它将首先检查共享的首选项.用户已购买物品的价值,如果没有,则转到购买请求,否则显示他/她的物品.
我的问题是,这是安全的方式吗?或者我必须做点什么?

解决方法

这不安全.我不鼓励你以这种方式实施这样的支票.您应该选择标准方法并使用 getPurchases()方法.您可以随时(甚至离线)调用方法,如果用户已购买,则会从该方法返回.这是一个示例代码
IInAppBillingService service; // initialize it first

Bundle response = service.getPurchases(3,"you app package","inapp",null);
int responseCode = response.getInt(KEY_RESPONSE_CODE);
if (responseCode == RESPONSE_OK) {
    ArrayList<String> purchases = response.getStringArrayList(KEY_INAPP_PURCHASE_ITEM_LIST);
    ...
}

对于诅咒,您需要验证购买是否使用正确的证书进行签名,并且购买状态不会被取消.但这比在共享属性中存储数据要安全得多.这种方法的另一个优点是,在用户重新安装应用程序后,所有购买也将在那里自动获得.

相关文章

以下为个人理解,如错请评 CE: 凭据加密 (CE) 存储空间, 实际路径/data/user_ce/ DE: 设备加密 (DE) 存...
转载来源:https://blog.csdn.net/yfbdxz/article/details/114702144 用EventLog.writeEvent打的日志(或...
事件分发机制详解 一、基础知识介绍 1、经常用的事件有:MotionEvent.ACTION_DOWN,MotionEvent.ACTION...
又是好久没有写博客了,一直都比较忙,最近终于有时间沉淀和整理一下最近学到和解决的一些问题。 最近进...
Android性能优化——之控件的优化 前面讲了图像的优化,接下来分享一下控件的性能优化,这里主要是面向...
android的开源库是用来在android上显示gif图片的。我在网上查了一下,大家说这个框架写的不错,加载大的...