喜接新项目往往预示的会出一堆问题。解决问题的同时往往也就是学到更多东西的时候,这也许就是学习到新东西最直接最快速的方法吧!
小编经过努力,新项目终于过测试了,可是被苹果大大给拒了,好苦啊,最近的审核真的是没有谁了。这回被拒是因为项目中存在私有api,下图为被拒信息。
这就坑了啊,这么大一个项目,我如何定位呢?
如果是代码里面运用到私有api,那就简单了,直接
command+Shift+F
,就可以定位了!prefs:root=
就是原来代码里面的,小编找到后果断删除了!
最麻烦的就是在第三方SDK中的私有api(com.apple.springboard.lockcomplete
),实在不知道如何定位了。在被拒消息中也提示了我们如何定位,百度+Google走一波,学习了一下,随便写个笔记。好记性不如烂笔头嘛!
方法1:strings检测
这个方法是我在被拒信息中看到的苹果大大建议的方法,步骤如下:
1、获取release的ipa包,打包是选择的方式为:App Store
2、将 .ipa 修改为 .zip,减压,获取到两个文件夹Payload、Symbols
3、打开命令行,cd 到 Payload 里面的 app,然后使用 strings 命令进行查找
strings - -a -arch armv7 "工程名" | grep com.apple.springboard.lockcomplete
还有一种命令,直接生成一个 txt 文件。
strings - -a -arch armv7 "工程名" > /Users/admin/Desktop/strings.txt
运行后会在桌面上出现一个 strings.txt
文件,文件的路径和名字随个人开发习惯
两种命令获取方式都没有定位到具体位置,只是告诉我们存在这个私有api
方法2:otool工具(xcode自带,可以直接在终端中使用)
前两步同方法1
terminal中 cd 到 Payload 里面的 app
然后使用如下命令
otool -L appName
这个命令会列出你所有使用的系统库,检查一下给出的列表中有没有私有api的库
如果对命令不熟悉还可以使用
otool -help
去查看命令帮助文档
方法3:全局搜索(建议使用)
这个方法是我认为最直接最有效的方法!
1、 cd 到你的工程目录
2、使用全局搜索命令(注意最后要加一个点)
grep -r lockcomplete .
这个方法直接定位到这个私有api出现在
AmazonFling.framework
中。
到这里,解决上述第三方库的私有API的问题,就是直接替换掉新的SDK,当然如果新的第三方库也有私有API的话,那就只能舍弃了,否则基本无解。
小编比较幸运,直接更换最新的 AmazonFling.framework
后,就消除了私有api(com.apple.springboard.lockcomplete
)。在发版前,使用这两个方法都进行了验证,私有api不存在了!
参考资料:
https://www.jianshu.com/p/921a8b2315ce