iOS上传AppStore被拒原因及处理方案
1.后台运行GPS
1.1 原文:
Performance - 2.5.4
Your app declares support for location in the UIBackgroundModes key in your Info.plist file but does not have any features that require persistent location. Apps that declare support for location in the UIBackgroundModes key in your Info.plist file must have features that require persistent location.
Next Steps
Please revise your app to include features that require the persistent use of real-time location updates while the app is in the background. Please also add the following battery use disclaimer in your Application Description:
"Continued use of GPS running in the background can dramatically decrease battery life."
If your app does not require persistent real-time location updates, please remove the "location" setting from the UIBackgroundModes key. You may wish to use the significant-change location service or the region monitoring location service if persistent real-time location updates are not required for your app features.
Resources
For more information, please review the Starting the Significant-Change Location Service and Monitoring Shape-Based Regions.
If you have difficulty reproducing a reported issue, please try testing the workflow described in Technical Q&A QA1764: How to reproduce bugs reported against App Store submissions.
If you have code-level questions after utilizing the above resources, you may wish to consult with Apple Developer Technical Support. When the DTS engineer follows up with you, please be ready to provide:
- complete details of your rejection issue(s)
- screenshots
- steps to reproduce the issue(s)
- symbolicated crash logs - if your issue results in a crash log
1.2 译文:
性能 - 2.5.4
你的应用程序在Info.plist文件中的key值"UIBackgroundModes"后台模式下声明支持"Location"定位但没有任何需要持久的"Location"定位的特点。应用程序在Info.plist文件的key"UIBackgroundModes"声明支持"Location"定位必须有需要持久定位的特征。
接下来的步骤
请修改你的应用程序,使它包含在后台模式下需要实时更新定位的功能。并且请你在您的应用程序描述中添加以下的电池使用免责声明:
“继续使用在后台中运行的GPS定位系统,将会大大降低电池寿命。”
而或者,如果你的应用程序不需要持续的实时位置更新,请在键"UIBackgroundModes"中清除"Location"的设置。你的应用程序的功能可能更希望使用更改显著的位置的服务"significant-change location service"或区域监控位置服务"region monitoring location service",而不是持续的实时位置更新"real-time location updates"。
资源
对于更多信息,请查看 Starting the Significant-Change Location Service 和 Monitoring Shape-Based Regions。
如果你对再现报告中提出的问题有困难,请尝试测试工作流程 Technical Q&A QA1764: How to reproduce bugs reported against App Store submissions。
如果您在使用上述资源后有代码级的问题,您可能希望与Apple Developer Technical Support协商。当DTS工程师跟踪你,请准备提供:
- 您拒绝问题(们)的完整细节
- 截图
- 重现问题(们)的步骤
- symbolicated crash logs - 如果你的问题导致崩溃的日志
在百度翻译基础上加工了一下,使它符合中国人的阅读习惯。
1.3 问题解决方案
这个问题是因为我在info.plist中添加了这样一行设置:
XML格式:
1 <key>UIBackgroundModes</key> 2 <array> 3 <string>location</string> 4 </array>
这个设置的用意就是在后台运行App的时候,依然实时请求定位信息。目前来看我的App是不需要这行设置的,所以我删了这一行就可以了应该,但具体结果还是等审核完毕再来修改。若你需要这样的功能,苹果要求你给用户添加一条对电池寿命的提示。
并不清楚为何会有这样一条设置,因为我翻阅我接手的代码版本是有这样一条设置的;但同时,过往有这条设置的版本,是已经上线了的版本。这很尴尬。
另外,还有一个地方需要设置。那就是:
用XML格式:
1 <key>NSLocationAlwaysUsageDescription</key> 2 <string>需要定位</string> 3 <key>NSLocationWhenInUseUsageDescription</key> 4 <string>需要定位</string>
干什么用的呢,这两条是向系统确认定位的权限的;若没有这两条,那么系统不会弹出请求用户授权定位的信息。同时要明确,NSLocationAlwaysUsageDescription始终 的优先级是高于NSLocationWhenInUseUsageDescription使用期间的。后面的字符串是你想展示给用户的信息。像这样:
NSLocationAlwaysUsageDescription始终:
NSLocationWhenInUseUsageDescription使用期间:
2.含UGC内容(User Generated Content指用户原创内容)却未提供用户协议及举报功能
2.1 原文:
Safety - 1.2
Your app enables the display of user-generated content but does not have the required precautions in place.
Next Steps
Please revise your app to implement all of the following precautions:
- Require that users agree to terms (EULA) and these terms must make it clear that there is no tolerance for objectionable content or abusive users.
- A method for filtering objectionable content.
- A mechanism for users to flag objectionable content.
- A mechanism for users to block abusive users.
- The developer must act on objectionable content reports within 24 hours by removing the content and ejecting the user who provided the offending content.
2.2 译文
安全 - 1.2
你的应用程序可以显示用户生成的内容,但没有到位必要的预防措施。
接下来的步骤
请修改您的应用程序来实现所有的以下预防措施:
- 要求用户同意条款(EULA),这些条款必须清楚,绝不容忍令人反感的内容或滥用权利的用户。
- 一种过滤不良内容的方法。
- 一个用户举报违反协定内容的机制。
- 一种用户阻止滥用权利用户的机制。
- 开发商必须在24小时内对包含不良信息的内容进行删除和逐出提供违规内容的用户。
2.3 解决方法
App有类似于贴吧的用户原创内容。苹果认为你如果允许用户发布原创内容的话,就要对用户发布的内容进行监管,不允许出现令人不适的内容。最终处理方式是:
1.最后,在详情页添加一个举报入口。
3.请求用户的定位信息却没有提示
3.1 原文
Legal - 5.1.5
We noticed that your app does not request and obtain the user's consent prior to accessing their location data, which is not allowed on the App Store.
Next Steps
Please revise your app to add the consent prompt for accessing the user's location data and to ensure the features are still functional if the user initially opts out.
3.2 译文
法律分析 - 5.1.5
我们注意到,您的应用程序在要求并获得用户的同意之前就访问了他们的位置数据,这在App Store是不允许的。
接下来的步骤
请修改你的应用程序,在访问用户的定位数据之前提示用户同意请求数据,并且若用户最初选择的不同意,你的功能依然可以实现(我理解是再次进入界面的时候依然询问是否允许定位?)。
3.3 解决方法
用的定位是AMapLocation,仔细观察了下似乎也确实没有提示,应该也没有用到系统的定位框架CoreLocation。解决方案目前想了两种,准备再考虑下使用哪一种:
1.直接来一个提示框,提示是否允许定位,不允许直接返回,允许就进入,同时将允许与否存在NSUserDefaults中;之后在个人设置里面加一个开关UISwitch,根据NSUserDefaults中的值决定是开还是关。
2.使用CLLocation处理定位。
似乎都很麻烦。