【发布时间】:2010-08-06 18:04:01
【问题描述】:
有没有办法以编程方式确定当前运行的应用程序是仅为开发而构建和签名的,还是为分发而构建的?是否可以确定是为应用商店构建还是为临时分发而构建?
是不是例如可能访问代码签名并从那里获取信息?或者是否有某些文件存在于其中一个变体中而其他变体中不存在?是捆绑信息的一部分吗?还是可以从可执行文件中导出?
感谢任何提示。
embedded.mobileprovision 文件似乎是 ASN.1 格式。
【问题讨论】:
有没有办法以编程方式确定当前运行的应用程序是仅为开发而构建和签名的,还是为分发而构建的?是否可以确定是为应用商店构建还是为临时分发而构建?
是不是例如可能访问代码签名并从那里获取信息?或者是否有某些文件存在于其中一个变体中而其他变体中不存在?是捆绑信息的一部分吗?还是可以从可执行文件中导出?
感谢任何提示。
embedded.mobileprovision 文件似乎是 ASN.1 格式。
【问题讨论】:
最简单的检查方法是查看embedded.mobileprovision ([[NSBundle mainBundle] pathForResource:@"embedded.mobileprovision" ofType:nil]):
openssl asn1parse -inform der),但一个不好的 hack 是只查找 <plist 和 </plist>。<key>get-task-allow</key><true/>
您可以检查的另一件事是嵌入在可执行文件中的权利(otool -l 将其列为LC_CODE_SIGNATURE)。解析这个更加繁琐(您需要解析 Mach-O 标头和加载命令,对于现在默认的“通用”二进制文件,您需要检查当前加载的架构或所有架构)。
<key>get-task-allow</key><true/>
<key>get-task-allow</key><false/>
我不认为权利区分 Ad Hoc 和 App Store 版本。
除了那些和它签署的证书之外,开发/临时/App Store 应用程序之间没有区别(权利/配置配置文件中还有一些其他内容,但没有比我能想到的更可靠的了)。
这些都不是那么难以规避的。对于第一种方法,应用程序可以“调酒”-[NSBundle pathForResource:ofType:]。第二种方法有点困难,具体取决于您使用什么 API 来读取文件。
【讨论】:
<key>ProvisionsAllDevices</key> <true/>
openssl asn1parse -inform DEM -in *Mobile_Provision_File* -strparse 54 是访问我找到的数据的最简单方法。
编辑:
security cms -D -i *Mobile_Provision_File* 实际上更容易。 openssl 命令在输出中留下了一些垃圾。
【讨论】:
我提取了一个 embedded.mobileprovision 文件并粘贴到一个在线 ASN.1 查看器(例如http://www.geocities.co.jp/SiliconValley-SanJose/3377/asn1JS.html)中,这就是我得到的:
SEQUENCE {
OBJECTIDENTIFIER 1.2.840.113549.1.7.2 (signedData)
[0] {
SEQUENCE {
INTEGER 1
SET {
SEQUENCE {
OBJECTIDENTIFIER 1.3.14.3.2.26
NULL
}
}
SEQUENCE {
OBJECTIDENTIFIER 1.2.840.113549.1.7.1 (data)
[0] {
OCTETSTRING 3c3f786d6c20766 ... 6c6973743e0a
}
}
[0] {
SEQUENCE {
SEQUENCE {
[0] {
INTEGER 2
}
... [much more]
有了这些和一些 ASN.1 知识,你的解释就很有意义了。
有趣的部分是从 3c3f786d6c 开始的八位字节串。这是 Apple 属性列表格式的 XML 部分,其中包含有关分发类型(开发者、临时、App Store)的所有答案。
【讨论】:
#if (DEBUG)
#define SERVER @"aaaa.com/dev"
#else
#define SERVER @"aaa.com/pro"
#endif
这就是我区分调试和发布模式的方式,
但我不知道临时或生产,除非使用配置文件名称
【讨论】:
我创建了一个 gist 来检测 Ad Hoc 构建
见:https://gist.github.com/iShawnWang/d904934efded271d83b36288562df410
1.embedded.mobileprovision 包含字段ProvisionedDevices(Debug and Ad Hoc Build 包含此字段,不发布)
2.不是DEBUG Build,我们可以用#ifdef DEBUG来判断
NS_INLINE BOOL isAdHoc(){
BOOL isAdHoc = NO;
BOOL isDebug;
#ifdef DEBUG
isDebug=YES;
#else
isDebug=NO;
#endif
NSData *data=[NSData dataWithContentsOfURL:[[NSBundle mainBundle]URLForResource:@"embedded" withExtension:@"mobileprovision"]];
NSString *str=[[NSString alloc]initWithData:data encoding:NSISOLatin1StringEncoding];
NSRange rangeOfDevicesUDIDs = [str rangeOfString:@"ProvisionedDevices"];
isAdHoc = rangeOfDevicesUDIDs.location!=NSNotFound && !isDebug;
return isAdHoc;
}
【讨论】: