我发现我的应用程序发生了一件非常奇怪的事情。
具体来说,当我检测到应用程序的 bundle 中不包含收据文件时,我正在发出收据请求以便从 Apple 下载收据。
当然,调用收据刷新 API 会导致显示 Apple ID 登录屏幕。
我在 iTunes Connect 中创建了“测试”/“沙盒”用户以测试我的应用程序。
在我的设备(带WiFi的iPad)上运行该应用程序时,该应用程序成功调用了刷新回执功能,然后果然弹出了Apple ID登录屏幕。我输入了在 iTunes Connect 中配置的测试/沙盒用户的正确凭据,一切正常(即收据已成功下载。)
但是,如果我尝试使用真实的 Apple ID 用户,我会收到“didFailWithError”并且本地化错误描述为:“无法连接到 iTunes Store”,错误代码为“16”。
在我看来,这是意料之中的事情。
现在,令人难过的是,当我将我的构建提交给 Apple Review 时,他们收到了上面提到的确切错误。
他们说他们正在使用沙盒用户,因此他们拒绝了该应用程序,因为他们无法继续。
注意:他们也使用带 WiFi 的 iPad 来测试应用程序。
只有在使用真实的 Apple ID 用户帐户时,我才能始终重现此问题,并且从未遇到过沙盒用户的问题!
我在某处读到,在测试时还必须确保沙盒用户已从“设置”屏幕注销。我已经礼貌地要求 Apple Review 确保他们在测试时不会登录到“设置”。
他们给我发了两张截图:一张是 Apple ID 登录屏幕,要求输入 BOTH Apple ID 用户和密码(这让我认为他们确实退出了“设置”屏幕,否则他们已经在对话框中预填充了 Apple ID 用户)和一个显示本文中提到的错误。
我现在不知道如何继续,因为我根本无法重现这个问题。它适用于我设备上的任何沙盒用户——只是不适用于真正的 Apple ID 用户。
Apple Review 向我发送了一张屏幕截图,显示了这篇文章中提到的错误,同样,这个错误只有在真正的沙盒环境中使用真实的 Apple ID 用户时才能重现。
我认为唯一的区别可能是我的设备运行的是 iOS 10.x 而他们的设备可能运行的是 iOS 12.x,但我认为这应该不是问题。
有什么想法吗?
提前致谢!
P.S.,他们没有使用我创建的 Apple ID 沙盒用户——他们使用自己的。我曾建议将我的沙盒用户发送给他们进行测试,但他们表示无法接受,因为这会侵犯隐私。
更新:我已经确认在 iOS 12.1 上也会发生同样的事情,所以这不是由于操作系统的差异。
最佳答案
至少在我看来,刷新收据 API 本身似乎有问题。
我已确认发起购买请求会导致应用从 Apple 下载收据,其中包含所提供用户(在我们的示例中为沙盒用户)的凭据。
审核团队已确认购买请求适用于他们的沙盒用户,但是,刷新收据不适用于完全相同的用户(它会导致代码 16,“无法连接到 iTunes Store”)!
我还确认“恢复”请求会导致下载收据,并且它适用于提供的沙箱用户。
总而言之,“购买”和“请求”操作都会导致应用程序从 Apple 下载收据,并且它们对于审核小组提供的沙盒用户可以正常工作。但是,对于完全相同的用户,收据刷新请求失败!
我仍然可以要求刷新收据,因为它应该适用于实际的 App Store 下载,但显然不适用于应用审查。
关于ios - Receipt Refresh导致Apple Review因iTunes Store连接错误拒绝App,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53311420/
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
我正在使用Sequel构建一个愿望list系统。我有一个wishlists和itemstable和一个items_wishlists连接表(该名称是续集选择的名称)。items_wishlists表还有一个用于facebookid的额外列(因此我可以存储opengraph操作),这是一个NOTNULL列。我还有Wishlist和Item具有续集many_to_many关联的模型已建立。Wishlist类也有:selectmany_to_many关联的选项设置为select:[:items.*,:items_wishlists__facebook_action_id].有没有一种方法可以
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我使用的是Firefox版本36.0.1和Selenium-Webdrivergem版本2.45.0。我能够创建Firefox实例,但无法使用脚本继续进行进一步的操作无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055)错误。有人能帮帮我吗? 最佳答案 我遇到了同样的问题。降级到firefoxv33后一切正常。您可以找到旧版本here 关于ruby-无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055),我们在StackOverflow上找到一个类
我是rails的新手,想在form字段上应用验证。myviewsnew.html.erb.....模拟.rbclassSimulation{:in=>1..25,:message=>'Therowmustbebetween1and25'}end模拟Controller.rbclassSimulationsController我想检查模型类中row字段的整数范围,如果不在范围内则返回错误信息。我可以检查上面代码的范围,但无法返回错误消息提前致谢 最佳答案 关键是您使用的是模型表单,一种显示ActiveRecord模型实例属性的表单。c
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
我克隆了一个rails仓库,我现在正尝试捆绑安装背景:OSXElCapitanruby2.2.3p173(2015-08-18修订版51636)[x86_64-darwin15]rails-v在您的Gemfile中列出的或native可用的任何gem源中找不到gem'pg(>=0)ruby'。运行bundleinstall以安装缺少的gem。bundleinstallFetchinggemmetadatafromhttps://rubygems.org/............Fetchingversionmetadatafromhttps://rubygems.org/...Fe
在Cooper的书BeginningRuby中,第166页有一个我无法重现的示例。classSongincludeComparableattr_accessor:lengthdef(other)@lengthother.lengthenddefinitialize(song_name,length)@song_name=song_name@length=lengthendenda=Song.new('Rockaroundtheclock',143)b=Song.new('BohemianRhapsody',544)c=Song.new('MinuteWaltz',60)a.betwee
这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下
我是Google云的新手,我正在尝试对其进行首次部署。我的第一个部署是RubyonRails项目。我基本上是在关注thisguideinthegoogleclouddocumentation.唯一的区别是我使用的是我自己的项目,而不是他们提供的“helloworld”项目。这是我的app.yaml文件runtime:customvm:trueentrypoint:bundleexecrackup-p8080-Eproductionconfig.ruresources:cpu:0.5memory_gb:1.3disk_size_gb:10当我转到我的项目目录并运行gcloudprevie