ios - AppStore/iOS 应用程序和解释代码——它们的界限在哪里?

标签 ios iphone app-store

Apple 的 iOS 开发者指南指出:

3.3.2 — An Application may not itself install or launch other executable code by any means, including without limitation through the use of a plug-in architecture, calling other frameworks, other APIs or otherwise. No interpreted code may be downloaded or used in an Application except for code that is interpreted and run by Apple’s Documented APIs and built-in interpreter(s).

假设下载数据 - 例如 XML 和图像,或游戏关卡描述 - 在运行时是允许的(这是我的印象?),我想知道他们在哪里绘制“数据”和“代码”之间的界线。想象一下向用户提供交互式“演示文稿”(例如调查)的应用程序场景。演示文稿不断添加到服务器,不同的演示文稿可供不同的用户使用,因此它们不能成为初始应用程序下载的一部分(这才是重点)。它们以 XML 格式描述,但由于是交互式的,它们可能包含此类条件分支(以伪形式显示以举例说明):

<options id="Gender">
    <option value="1">Male</option>
    <option value="2">Female</option>
</options>

<branches id="Gender">
    <branch value="1">
        <image src="Man" /> 
    </branch>
    <branch value="2">
        <image src="Woman" /> 
    </branch>
</branches>

当此 XML 在应用程序中被解释和“播放”时,上述内容将分两步呈现。首先显示一个选择屏幕,用户可以在其中单击两个选项(“男性”或“女性”)中的任何一个。接下来,将根据上一步中的选择 [动态下载] 并显示图像。

现在,由此,很容易想象出额外的标签,仍然描述更多的逻辑。例如,可以添加一个包含标签:

<loop count="3">

    <options... />
    <branches... />

</loop>

当然,这里的结果是选择屏幕/图像屏幕对将依次呈现 3 次以上。

或者想象一些描述游戏中关卡的格式。将其视为被动“数据”也许是很自然的,但如果它包括,比如说,用户可以通过的几个门口,并带有各种触发器、陷阱和附加到它们的点等——这与使用脚本(或者实际上是解释代码)- 描述执行序列、选项及其条件响应?

假设数据的解释引擎已经存在于应用程序中,并且此类“演示”只能在应用程序中使用(不能创建或编辑),这与 Apple 的 iOS 指南有何不同?从这个意义上说,XML 基本上不构成一种脚本语言吗(解释语言中的任何程序都不能用 XML 来描述)吗?

如果专有脚本语言(引用上面使用的 XML)被严格沙盒化(他们怎么知道?)并且不以任何方式访问操作系统(但能够下载内容 - 比如调查或游戏级别 - 动态以及上传结果 - 答案或分数 - 到创作服务器)?

这条线去哪儿了?

最佳答案

截至 WWDC 2017 的更新

下面提到的 Codea 等编程工具现在明确允许下载代码。 App Store Guidelines目前说(强调我的):

2.5.2 应用程序应在其 bundle 中自包含,不得在指定容器区域之外读取或写入数据,也不得下载、安装或执行代码,包括其他应用程序. 旨在教授、开发或测试可执行代码的应用程序可以在有限的情况下下载代码,前提是此类代码未用于其他目的。此类应用必须使应用提供的源代码完全可供用户查看和编辑。

还有this tweet引用有关宽松条款的更多细节。

原创

您的解释性下载是否允许用户编写无限循环或递归?

Apple 允许使用 Javascript,因为它们提供解释器并且可以终止您的代码。我有一种感觉,我读到它有 10 秒的限制,但我在网站上搜索了几分钟后找不到它。 (是的,我自己设置的写答案超时开始了。)

我认为如果您所做的是声明式的并且不允许在解释器中出现明显的循环,那么您是非常安全的。

我还会避免在 Apple 可见的任何描述(包括公开讨论)中使用“解释器”一词。也许“解析器”会更安全。

Codea 在他们的 Lua 环境中滑过了这些定义的边缘,无法下载代码。他们 had to remove a feature用于将新包下载为“.codea”文件。

关于ios - AppStore/iOS 应用程序和解释代码——它们的界限在哪里?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12972802/

相关文章:

ios - 如何从重复的 JSON 键 iOS 中获取值

ios - 检测 UIImage 是否不包含图像

ios - 苹果因为 animationDidStop :finished:context: is a non-public api 拒绝了应用

iphone - 蓝牙跨平台 android, iphone, Blackberry, Symbian, WinMo

ios - 获取节索引路径和编辑节标题

iOS:设备上的自定义位置

iphone - 自动调整 UITableViewCell 中 UILabels 的大小

ios - iTunes Connect 无法删除应用程序

geolocation - 如何在后台正确使用位置 - 应用被拒绝 3 次

iphone - 如何检查 iPhone 应用程序用户是否评价或评论过该应用程序