1. 什么是APP schemeURL
玩手机时经常会碰到浏览器里提示“是否打开某APP”,或者微信/QQ等应用里提醒“即将跳转到外部应用”,尤其是知乎/百度/CSDN等内容平台,不厌其烦的提示用户“在APP中打开”,其实不过是为了诱导用户下载其APP。
这种外部唤醒应用且能到达指定页面的方法,就是通过schemeURL实现的,在安卓开发中叫做intent,也就是脚本作者所说的“意图”。
具体可以看一下这篇文章的详细介绍:传送门
2. 如何查找某一APP的schemeURL
(1)WEB端
想找到某一应用的schemeURL,也就是intent,最简单粗暴的方法,就是打开会提示“是否打开某APP”的页面(一般就是个普通网页链接),右键查看页面源代码,里面就有包含scheme://
字样的内容,这个结束对应的schemeURL了。
以抖音为例:
- APP端找到某人主页(作品也可以),点击分享,复制链接,再到浏览器打开此链接。
- 浏览器打开调试界面(F12),点击移动设备模式,勾选Preserve log(保留日志),再点击【关注】,具体位置见下图。
- 点击之后可以看到,Network栏出现了一个红色的请求,这个就是schemeURL的请求,功能是打开抖音APP并且关注该用户。
- 点进去看一下,可以看到URL是
snssdk1128://user/profile/98726798113?refer=web&gd_label=click_wap_profile_follow&type=need_follow&needlaunchlog=1
,这个是带有各种各样参数的schemeURL,如果只要这一个,那到这一步就完成了。 - 如果想找找有没有别的,可以在搜索面板或者请求列表中搜索这个URL:先在左侧点击一下那个红色URL,然后Ctrl+F,搜一下
snssdk1128://
(不能搜整条URL,因为URL里参数一般都是前端处理之后加上去的) - 这里搜到两个结果,第一个是之前看到的红色URL,双击进入另一个查看。
- 点一下花括号
{ }
进行格式化,再点一下右侧代码区,才能Ctrl+F,一样的搜索snssdk1128://
- 结果如下图,各种参数都标记好了。
(2)安卓端
- 反编译apk
- 打开
AndroidManifest.xml
,搜索scheme
或者android.intent.action.VIEW
根据对应的Activity名称
aweme
,可以定位到:<activity android:launchMode="singleTask" android:name="com.ss.android.ugc.aweme.app.DeepLinkHandlerActivity" android:noHistory="true" android:screenOrientation="portrait" android:theme="@style/t"> <intent-filter> <action android:name="com.ss.android.sdk.snssdk1128"/> <category android:name="android.intent.category.DEFAULT"/> </intent-filter> <intent-filter> <action android:name="android.intent.action.VIEW"/> <category android:name="android.intent.category.DEFAULT"/> <category android:name="android.intent.category.BROWSABLE"/> <data android:scheme="snssdk1128"/> </intent-filter> </activity>
- 这里已经知道schemeURL是
snssdk1128://
了,就在反编译的内容里搜一下这个就能搜到所有的schemeURL了。
(3) iPhone端
- 将下载下来的ipa文件(可以用爱思助手下载)直接解压
- 以抖音为例,进入目录
\抖音短视频_7.7.0(正版)\Payload\Aweme.app\
- 打开
Info.plist
文件 搜索
CFBundleURLName
,其中<string>
里就是对应的scheme,比如抖音的就是snssdk1128://
<dict> <key>CFBundleTypeRole</key> <string>Editor</string> <key>CFBundleURLName</key> <string>com.ss.iphone.ugc.Aweme</string> <key>CFBundleURLSchemes</key> <array> <string>snssdk1128</string> </array> </dict>
总结
要找一个APP的schemeURL,可以按一下顺序尝试:
- 先看有没有什么分享链接是会唤起App的,如果有,直接参照(1)来查找暴露的schemeURL(一般都会带拼接好的参数);
- 如果没有WEB端,就参考(2)进行反编译来查找schemeURL(参数要自己拼凑尝试了)
- 如果上面两步没有成功,只能通过iOS端进行查找schemeURL(只有一个开头,也就是只能唤醒APP,无法到达指定页面)
补充
通过xposed框架也可以抓取非普通schemeURL的intent和参数。
除了普通schemeURL外,APP还有一种跳转方法,并没有使用schemeURL,只是内部activity跳转,有时候脚本开发也会很需要。
一次APP算法解密时偶然发现,通过xposed的hook插件inspackage可以查看activity跳转,包括所带参数。虽然并未具体测试可用性,但确确实实跳转记录和参数都有了,估计也是可以用的。
以下xposed插件也是类似的(未测试):
- 隐式启动
- intent记录
- Intent拦截者
各种开发工具使用schemeURL或intent的方法见另一篇文章。