iOS SiriKit 开发指南
需求背景
公司业务需求,开发 Hi siri 响应功能数据展示回应需求
data:image/s3,"s3://crabby-images/316f2/316f289fcc9d29bae25155ebb6267e892d1587e7" alt=""
明确需求确定技术实现方案:
- 第⼀阶段:通过快捷指令实现,通过指导⽤⼾安装定制的快捷指令即可:
- 优点:不启动 APP,直接在弹出的扩展进程中处理相关指令操作;
- 痛点:需要定期替换 token,⼿动体验不是很好,⽽且维护成本⽐较⾼,容易泄露信息;
- 第⼆阶段:打通应⽤⸺通过 Siri 指令唤起: 直接启动 APP,在 APP 独⽴进程中处理相关指令操作,⽐如展⽰今天项⽬的报表,直接进⼊ ⻚⾯展⽰;
开发准备
- 我的开发者账号信息:https://appstoreconnect.apple.com/login
- 官⽅开发者⽂档:https://developer.apple.com/cn/
- 团队名称:xxx
- 账⼾ID:xxx
- Bundle Identifier:xxx
- uni-app 应⽤后台:https://dev.dcloud.net.cn/pages/common/login
- SiriKit 开发官⽅说明:https://developer.apple.com/videos/play/wwdc2020/10073/
- 作为 App 的⼀种扩展插件形式执⾏处理,并不需要打开 App;
- 10 秒超时时间限制;
前置⽬标
data:image/s3,"s3://crabby-images/3ae21/3ae2117b71f44d8df3026686714d0d96176c70e1" alt=""
- 如果需要开发⼀个原⽣插件包的形式,创建项⽬的时候选择哪个模版?
- 信息列表属性可以配置值为中⽂吗?
- 怎么打包运⾏到真机上?
- 打包构建的配置信息怎么设置?
data:image/s3,"s3://crabby-images/626f0/626f05ea227ab44a6cd265220c7d526ae5ee11e7" alt=""
- 信息存储本地化;
- 应⽤⽣命周期及⼊⼝⽂件?
a. Managing your app’s life cycle | Apple Developer Documentation
b. About the app launch sequence | Apple Developer Documentation
- 是否需要添加 Siri 的访问权限? 处理应⽤程序 SiriKit 的权限版本: https://developer.apple.com/documentation/uikit/uiapplicationdelegate/3548063-application
data:image/s3,"s3://crabby-images/38316/38316861fa5ef15b916f78964b0b7ef9eec8b741" alt=""
操作说明
- iOS 系统限制 10.0+/ 12+ custom intent,iOS 13+,因为之前版本仅⽀持快捷⽅式添加到快捷指 令,不⽀持输⼊询问参数
在 iOS 13.1 中,Apple 赋予了 SiriKit 更多权限,可以通过 Siri 对话框在⾃定义 Intent 中询问⽤⼾输⼊参数
- 确保⼿机有【快捷指令】App 和 iOS 12+;
开发说明
Xcode 开发⼯具版本:V14.3.1
注意: • 应⽤运⾏到模拟器并不代表真实的运⾏环境,还是需要真机预览的,但是真机预览需要付费开发者 会员才可以;
开发环境搭建
- Xcode 软件下载:App Store 直接搜索 Xcode 下载即可,注意有 MacOS 系统版本限制
data:image/s3,"s3://crabby-images/96c55/96c555e89732ba546c53db65fe2755a7d786f330" alt=""
- 运⾏打开,默认选择运⾏终端选项:Mac 和 iPhone 即可
data:image/s3,"s3://crabby-images/2591d/2591d8132e2d7627ac22d920fddeef2b45dea786" alt=""
提⽰特性:
data:image/s3,"s3://crabby-images/32ca8/32ca8840f7c4c7ae67cbab33ab7f586bb2b53c8d" alt=""
- 创建项⽬:
data:image/s3,"s3://crabby-images/f7fc8/f7fc888a61b5b1d40b0cd94305acd62a5b1a7b23" alt=""
data:image/s3,"s3://crabby-images/fe622/fe622e7c119a51df9a7b3ea58b8ab01ce4fdb10f" alt=""
- Team: Organization identifier:
- 项⽬添加siri启动配置:
data:image/s3,"s3://crabby-images/31db5/31db5081944b87fbb678386adc3f5b30f9055710" alt=""
data:image/s3,"s3://crabby-images/a428b/a428be880c1b320261a6f6f17f3bc6783cc2bb5c" alt=""
data:image/s3,"s3://crabby-images/6c35b/6c35b9152787d5d28edca2658a6dfa78f431d2fa" alt=""
切换运⾏的模拟器:
data:image/s3,"s3://crabby-images/50426/504268f99c16a6966bcf0d55d4642194978c3a57" alt=""
运⾏到真机上必须是开发者团队才可以:
⼿机需要开启开发者模式:设置=》隐私与安全性=》开发者模式
data:image/s3,"s3://crabby-images/a55de/a55de8c12da239e30610d5b4df875d0e49161afb" alt=""
如果没有配置开发者团队的话,需要在这⾥配置设置:
data:image/s3,"s3://crabby-images/4ea1a/4ea1a553b2645fa0c5824c4293622256f975fd10" alt=""
使⽤Siri默认语⾳提⽰配置:
data:image/s3,"s3://crabby-images/de7b6/de7b643cb6ee57084c15514bab9b679144e57048" alt=""
使⽤ intent 扩展提⽰报错,需要打钩上这些引⼊包选项:
data:image/s3,"s3://crabby-images/ffd73/ffd737ca4f6c5f4f1be2f3e7d5a3e94812bf280c" alt=""
给对应的应⽤设置Siri权限:
data:image/s3,"s3://crabby-images/73a01/73a01a6984138bcb502e2d7c2bba38b9ad4e686b" alt=""
快捷指令的应⽤⽆需调⽤访问 Siri 的权限: https://developer.apple.com/documentation/sirikit/intent_handling_infrastructure/requesting_ authorization_to_use_siri
data:image/s3,"s3://crabby-images/2f8a7/2f8a7db37149d63782462195f604523425fb3078" alt=""
官⽅创建意图扩展教程:Creating an Intents App Extension | Apple Developer Documentation 并且:⾸次安装扩展应⽤时,Siri 并不会⽴⻢识别这个快捷指令,需要等待⼏分钟在进⾏测试使⽤,包 括更新扩展⽂件也是的
data:image/s3,"s3://crabby-images/393ac/393ac5248a3ae5cc3cfc4c00ac2662f3ed5fe32e" alt=""
应⽤连不上⽹络问题是:应⽤需要允许⽆线局域⽹开启连接,⾸次安装应⽤会有弹出授权⽆线局域⽹ 的弹窗提⽰,开启的话可以在:设置=》⽆线局域⽹=》使⽤⽆线局域⽹与蜂窝⽹络的 App=》找到该应 ⽤是否存在
data:image/s3,"s3://crabby-images/8be2e/8be2e4251967d039a98c74e408f150c131a3c59c" alt=""
https://www.jianshu.com/p/81d0b7f06eba 出现这种Siri提⽰直接点击打开这个应⽤即可,跳转到对应的应⽤打开蜂窝⽹络数据或⽆线⽹络权限
data:image/s3,"s3://crabby-images/80467/80467d533f822f132b23e298e019449c3a1226fc" alt=""
接⼝调⽤成功:
data:image/s3,"s3://crabby-images/a09b6/a09b6254f59cf94ebd8c7bf7837362d97e0f64eb" alt=""
Xcode 模拟器不⽀持 Siri 功能使⽤:https://developer.apple.com/forums/thread/131319
data:image/s3,"s3://crabby-images/75783/75783e5d677ab164c28ce4e927bf9f7d28464cd7" alt=""
开发语法
- 打印调试信息⽇志:
print("这个是调试信息")
- 获取应⽤访问 Siri 权限:
1 import IntentsINPreferences.requestSiriAuthorization {
2 switch $0 {
3 case .authorized:
4 print("⽤⼾已授权")
5 break
6 case .notDetermined:
7 print("未决定")
8 break
9 case .restricted:
10 print("权限受限制")
11 break
12 case .denied:
13 print("拒绝授权")
14 break
15 }}
- 是否需要添加 Siri 的访问权限?
- SiriKit ⼊⼝开发说明: https://developer.apple.com/documentation/uikit/uiapplicationdelegate/3548063- application
- 请求接⼝:https://developer.apple.com/documentation/uikit/uiapplication/1648685-open
1 func open(
2 _ url: URL,
3 options: [UIApplication.OpenExternalURLOptionsKey : Any] = [:],
4 completionHandler completion: ((Bool) -> Void)? = nil
5 )
https://developer.apple.com/documentation/uikit/uiapplication/openexternalurloptionskey 请求后端接⼝: https://www.jianshu.com/p/9acee6fdc32d Intent info.plist ⽂件说明
1 IntentsSupported:⽀持的 Intents 类型列表;
2 IntentsRestrictedWhileLocked:限制使⽤该 Intents 前必须解锁,也是⼀个列表;
3 NSExtensionPointIdentifier:必须为apple.intents-service;
4 NSExtensionPrincipalClass:Intents 扩展的⼊⼝⽂件,默认为
$(PRODUCT_MODULE_NAME).IntentHandler
官⽅解释: https://developer.apple.com/documentation/bundleresources/information_property_list
语法上跟 JavaScript 差异
- 默认的类型声明推到(Type Inference);
- 变量⽤ var 声明,常量⽤ let 声明;
- If/switch/for/while/do while 等循环语句不需要写括号 () ;
- Switch 中默认 case 匹配到了就不会往下执⾏,相当于默认写了 break ,匹配多个值⽤逗
1 // JavaScript
2 case "a":
3 case "b":
4 doSomething
5
6 // Swift
7 case "a", "b":
8 doSomething
- 打包: 最新版iOS Xcode如何证书配置和ipa打包(附图⽂教程) - 掘⾦ ⽣成导出的证书:钥匙串访问 =》
data:image/s3,"s3://crabby-images/2564f/2564f263e6fd547bb52652f9f7f7d8fc3c4296ba" alt=""
Uni-app 原⽣插件开发
官⽅⽂档:
注意:仅⽀持 iOS11 及以上系统版本
data:image/s3,"s3://crabby-images/b5c5a/b5c5a077e33089b39b456b45afbad641629fead0" alt=""
需要在 package.json ⾥添加如下配置:
1 "ios": {
2 "deploymentTarget": "11.0",
3 "validArchitectures": [
4 "arm64"
5 ],
6 }
本地离线打包测试: 配置AppKey:
data:image/s3,"s3://crabby-images/a6c56/a6c56ee4a7d4f776e04f3a2a9da1c0dd19e87008" alt=""
打包配置:
data:image/s3,"s3://crabby-images/b2746/b27460a933b6f067e0c1a5096a31ddd1414b9117" alt=""
注意:要有该应⽤的开发权限
data:image/s3,"s3://crabby-images/8c886/8c886dd2d650722bbc383e361e7da197da63e712" alt=""
编译报错:
data:image/s3,"s3://crabby-images/00f97/00f97dba60dc346318dbcc4dbf5d57acdbc04692" alt=""
取消勾选即可:
data:image/s3,"s3://crabby-images/77f92/77f92ba4b1b2fa4526aec806343858a7772c8f3d" alt=""
data:image/s3,"s3://crabby-images/c7c34/c7c3446d0c0491a2ee6c17982ea16377c706ec43" alt=""
苹果官⽅管理后台添加应⽤ Siri 能⼒配置:
data:image/s3,"s3://crabby-images/7e3d6/7e3d69cf14f5eadf8067504068676bfa8334f167" alt=""
打包插件不显⽰ build ⽂件问题:Xcode 13新建项⽬查看Products⽬录 - 掘⾦
因为编译根⽬录⽂件找不到的问题,每次打包需要⼿动添加对应的⽂件到uni-app⾥⾯去:
data:image/s3,"s3://crabby-images/84f70/84f70c94a83f364caa1d79c227629f1b8faf013c" alt=""
⼿动【快捷指令】添加的Siri⽆法触发⾃定义Siri意图指令,需要⼿动添加⽂件映射:
data:image/s3,"s3://crabby-images/c95b0/c95b0e876852aceb7b96374b7b7b844ce3a3ae2c" alt=""
data:image/s3,"s3://crabby-images/03098/03098fcb2a60ee4fa4a3c9eb3f12aaf3f4d5f9fb" alt=""
添加意图扩展⽂件报错:
data:image/s3,"s3://crabby-images/412d3/412d388f1ee519af2569677c7ab50f72edd9c14d" alt=""
解决复制意图扩展⽂件到跟⽬录:
data:image/s3,"s3://crabby-images/b1aa4/b1aa40427fd4b7189aae48f19c98c492694699f0" alt=""
data:image/s3,"s3://crabby-images/cb183/cb18339840a66b598bc5c5d0b8d4ad7cac1bd7bb" alt=""
data:image/s3,"s3://crabby-images/614da/614dabf3f201e47781e0ecfd835175169dc4db5e" alt=""
data:image/s3,"s3://crabby-images/ed475/ed475a08cb16f7d5b7ea47a1cd8b88e560a094a1" alt=""
查看打包⽂件地址:
data:image/s3,"s3://crabby-images/eb6a2/eb6a25dc0248d4c7993bd7feac93159bfb42fa19" alt=""
查看具体包⽂件内容:
data:image/s3,"s3://crabby-images/423a9/423a9993fdbb27a8964afa58323e419fa71a3b9e" alt=""
XBuilder 本地打包 ipa 配置:
data:image/s3,"s3://crabby-images/0468c/0468cfdc824014a47d34a2ad5df918652e176fbd" alt=""
HBuilder-云打包报错:
data:image/s3,"s3://crabby-images/dbdc7/dbdc791b4d1e86b747c70f6d4ddc6483d7692102" alt=""
升级替换这个⽂件:在苹果开发者后台下载对应的⽂件替换
data:image/s3,"s3://crabby-images/7c31b/7c31b8529920032f07a968430afb1b5c35b05aa3" alt=""
下载ipa包到真机iPhone上: iPhone, iPad 安装 ipa ⽂件_爱思助⼿安装ipa⽂件_Hanyang Li的博客-CSDN博客
IPA 解包及导⼊真机 http://dantheman827.github.io/ios-app-signer/
data:image/s3,"s3://crabby-images/52180/5218053a68f6a520bec8c957dd1f64f445861ee1" alt=""
将HBuilder⽣成的ipa包进⾏重命名解压(修改后缀格式为:zip):
data:image/s3,"s3://crabby-images/666e3/666e354fe06a3fe5eb3138d3d6d5e400f44facce" alt=""
- 传输 ipa 包到真机⼯具:苹果官⽅软件,⽐爱思助⼿安全可靠且⽅便
data:image/s3,"s3://crabby-images/7810e/7810e92e3778a0d10e8149c3e7d76e513f6aede1" alt=""
参考资料
Sirikit 开发: • 官⽅:在 iPhone 或 iPad 上创建⾃定快捷指令 ✅ • 学习:快捷指令库✅ • ⾯向开发者的 Siri✅ • 通过 Siri、“快捷指令”App 或“Siri 建议”运⾏快捷指令✅ • SiriKit官⽅⽂档📖 • SiriKit框架详细解析(⼀)⸺基本概览(⼀)✅ • 了解如何借助 Apple SiriKit 将 Siri 与您的应⽤程序集成📖 • Apple Siri接⼊开发 (⼀)✅ • iOS开发-SiriKit应⽤✅ • 玩转iOS开发:iOS 10 新特性《Siri Kit》✅ • iOS 开发:SiriKit 应⽤⼊⻔ • Introducing SiriKit Media Intents - WWDC19 - Videos - Apple Developer • Introducing Parameters for Shortcuts - WWDC19 - Videos - Apple Developer • Introduction to Siri Shortcuts - WWDC18 - Videos - Apple Developer • 介绍SiriKit · SiriKit编程指南 • Simulator Help • 创作者的 iOS 独⽴开发指南的⽬录 - 少数派 • Siri快捷指令 - 掘⾦ • SiriKit预研 • https://medium.com/@WeAreMobile1st/how-to-handle-and-donate-siri-shortcutsea50f2409086 • https://developer.apple.com/tutorials/swiftui/creating-and-combining-views • Siri,快捷指令以及 SiriKit - 探索 - Apple Developer • SiriKit 新变化:让 Intent 更强⼤_普通⽹友的博客-CSDN博客 • sirikit - o.0...w - 博客园 • iOS12 Siri Shortcuts详解 - 掘⾦ • 【腾讯 Bugly ⼲货分享】iOS10 SiriKit QQ 适配详解 - 掘⾦
实践⽂档: • 爱奇艺iOS深度实践:SiriKit详解应⽤篇 • SiriKit 编程指南 • 使⽤SiriKit在iOS的⽤⼾体验设计⽅法 (UX) • SiriKit 知⼀⼆ - Siri 捷径从设计到构建(上) • 向远公园⽂章系列 • 阿⾥云社区⽤⼾关于这个教程开发 • 阿⾥云sirikit⽂章搜索⻚⾯ • Google 关于 sirikit的开发搜索 • https://medium.com/search?q=sirikit • Siri Shortcuts intent 扩展开发 • https://www.jianshu.com/u/be22fcd3469d • https://www.jianshu.com/search?q=sirikit&page=1&type=note • https://www.jianshu.com/u/0cf7d455eb9e • https://juejin.cn/search? query=sirikit&utm_source=gold_browser_extension&utm_medium=search&sort=0 • https://juejin.cn/user/3227821827957710/posts • SiriKit 新变化:让 Intent 更强⼤_intent • Xamarin.iOS 中的 SiriKit - Xamarin • https://s.geekbang.org/search/c=0/k=sirikit/t= • 知乎 SiriKit 实战 • https://www.zhihu.com/search?type=content&q=sirikit • https://zzk.cnblogs.com/s?w=sirikit • https://medium.com/appcoda-tutorials/building-custom-siri-shortcut-intent-ui-extension-todisplay-remote-data-alfian-losari-efe891a44a70
Swift 编程开发: • SwiftGG • https://swift.gg/ • The Swift Programming Language (5.9 beta) | Documentation • Swift学习笔记 • Swift知识介绍 • 调试技巧 - 掘⾦ • https://developer.apple.com/documentation/swift
社区讨论: • 掘⾦对应ios开发:不想做iOS了; • Uni-app QQ群;
GitHub demo: • https://github.com/AbMathur/SirikitDemoApp • https://github.com/domeniconicoli/SiriKitIntentsUIExample • https://github.com/hanyx1992/SiriKitDemo
Xcode ⼯具开发: • 1.1 软件简介及准备⼯作 - 少数派 • Creating an Xcode project for an app | Apple Developer Documentation • Xcode⼊⻔秘籍⸺很多iOS开发者都不知道的基本操作 • 初 识 Xcode · macOS开 发 教 程 • Xcode - 简体中⽂⽂档 - Apple Developer • mac 下 Xcode 真机调试 - 掘⾦ • iOS⾃制framework总结 - 掘⾦
Uni-app 原⽣插件开发资料: • ⼋、uni-app 原⽣插件开发04 - 开发原⽣插件 • ⼀、iOS 中的动态库、静态库和 framework • 五年陈的 Weex,聊聊它的过去现在和未来 • WEEX • UNIAPP---IOS端原⽣插件开发实战(⼀) - 掘⾦