也就是说,Apple 规定的执行此操作的惯用方法是什么? 如有任何建议,请解释应该如何完成和/或提供官方指南的链接。这应该是一个足够常见的场景,但我只能找到解决方法。
从另一端接近这个,我知道UserDefaults(suiteName:)和 Keychain services可以从包含的应用程序中使用以通过扩展程序共享有关经过身份验证的用户的信息,但是如果用户安装了该应用程序并直接跳到尝试使用其扩展程序共享内容而无需登录(或注册)怎么办?
要求用户登录包含的应用程序?(在自定义 View 中?Extensions are modal by default.)
在扩展中重新实现身份验证?(或通过自定义框架共享?这可能吗?)
切换到包含的应用程序然后返回? 除了 Today 扩展,这似乎不受支持,但是 docs 中描述的机制已用于解决方法(SO 线程:1、2、3)。
第 2 项的(丑陋的)示例实现 in this answer使用 Firebase。
最佳答案
我找不到任何官方指南,但下面的解决方案确实有效,而且也被 App Store 接受了。底线可能就是:(1) 它不应该崩溃,并且 (2) 应该能够通过审核过程。
[FirebaseUI 身份验证[( https://github.com/firebase/FirebaseUI-iOS )] 的解决方案:
相关代码部分:
import UIKit
import Social
import Firebase
import FirebaseAuthUI
class ShareViewController: SLComposeServiceViewController {
var authUI: FUIAuth?
/* Using shared container to communicate between extension
and containing app. Keychain would probably work too.
*/
let defaults = UserDefaults.init(suiteName: "your-app-group")!
override func presentationAnimationDidFinish() {
/* https://stackoverflow.com/questions/37910766/
*/
if FirebaseApp.app() == nil {
FirebaseApp.configure()
}
self.authUI = FUIAuth.defaultAuthUI()
self.authUI?.delegate = self
if self.defaults.bool(forKey: "userLoggedIn") == false {
let fuiSignin =
FUIPasswordSignInViewController(
authUI: FUIAuth.defaultAuthUI()!,
email: nil)
let navController =
UINavigationController(rootViewController: fuiSignin)
self.present(navController, animated: true)
}
}
/* FirebaseAuthUI delegate to handle sign-in
*/
extension ShareViewController: FUIAuthDelegate {
func authUI(_ authUI: FUIAuth, didSignInWith user: User?, error: Error?) {
if error != nil {
fatalError()
}
if user != nil {
self.defaults.set(true, forKey: "userLoggedIn")
}
}
}
成功登录也会通过共享容器被记住(即,打开包含的应用程序不会要求登录)。
github项目中的相关commit: https://github.com/society-for-the-blind/Access-News-Reader-iOS/commit/e752b1c554f79ef027818db35c11fceb1ae817e0
问题
我第一次运行它时,出现了表单,但不接受任何输入。执行了 Product > Clean 和 Product > Clean Build Folder ...,重新启动了 Xcode 和模拟器,它成功了。它也适用于旧 iPad (iOS 10.3.3)。
关于ios - 如何在 iOS 共享扩展中正式处理未经身份验证的用户?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49134868/
出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits
我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..
如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby
我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby中使用两个参数异步运行exe吗?我已经尝试过ruby命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何rubygems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除
鉴于我有以下迁移:Sequel.migrationdoupdoalter_table:usersdoadd_column:is_admin,:default=>falseend#SequelrunsaDESCRIBEtablestatement,whenthemodelisloaded.#Atthispoint,itdoesnotknowthatusershaveais_adminflag.#Soitfails.@user=User.find(:email=>"admin@fancy-startup.example")@user.is_admin=true@user.save!ende
我正在编写一个gem,我必须在其中fork两个启动两个webrick服务器的进程。我想通过基类的类方法启动这个服务器,因为应该只有这两个服务器在运行,而不是多个。在运行时,我想调用这两个服务器上的一些方法来更改变量。我的问题是,我无法通过基类的类方法访问fork的实例变量。此外,我不能在我的基类中使用线程,因为在幕后我正在使用另一个不是线程安全的库。所以我必须将每个服务器派生到它自己的进程。我用类变量试过了,比如@@server。但是当我试图通过基类访问这个变量时,它是nil。我读到在Ruby中不可能在分支之间共享类变量,对吗?那么,还有其他解决办法吗?我考虑过使用单例,但我不确定这是
我正在为一个项目制作一个简单的shell,我希望像在Bash中一样解析参数字符串。foobar"helloworld"fooz应该变成:["foo","bar","helloworld","fooz"]等等。到目前为止,我一直在使用CSV::parse_line,将列分隔符设置为""和.compact输出。问题是我现在必须选择是要支持单引号还是双引号。CSV不支持超过一个分隔符。Python有一个名为shlex的模块:>>>shlex.split("Test'helloworld'foo")['Test','helloworld','foo']>>>shlex.split('Test"