我正在使用 Deezer iOS SDK ,到目前为止,在 Swift 中,除了 session 之外,一切都进行得很顺利,在 Android SDK 中,存在一个方法 .restoreSession() 以避免每次弹出用户登录,但我在 iOS SDK 中看不到它,所以每次 session 过期时,用户都会弹出窗口以使用 hi 的 Deezer 帐户再次登录,无论如何要在 iOS SDK 中保存或恢复 session ?
这是 Android 恢复 session 代码:
// restore any saved session
SessionStore sessionStore = new SessionStore();
if (sessionStore.restore(deezerConnect, context)) {
// The restored session is valid, navigate to the Home Activity
Intent intent = new Intent(context, HomeActivity.class);
startActivity(intent);
}
是否也可以在 iOS SDK 中执行此操作?
因为当用户使用 Deezer SDK 登录时,我没有收到委托(delegate)的通知
class DeezerSession : NSObject, DeezerSessionDelegate
{
var DZRReqManager:DZRRequestManager = DZRRequestManager()
var deezerConnect:DeezerConnect!
let defaults = UserDefaults.standard
var callbackLogin : (()->())? = nil
//SHARED INSTANCE
static var instance: DeezerSession!
class func sharedInstance() -> DeezerSession {
if self.instance == nil
{
self.instance = DeezerSession();
}
return self.instance
}
override init()
{
super.init()
self.deezerConnect = DeezerConnect(appId: "***" , andDelegate: self )
self.DZRReqManager.dzrConnect = self.deezerConnect
self.deezerConnect.sessionDelegate = self
self.retrieveTokenAndExpirationDate()
}
// See http://www.deezer.com/fr/developers/simpleapi/permissions
// for a description of the permissions
func connectToDeezerWithPermissions()
{
print("[DeezerSession] connectToDeezerWithPermissions.")
//Check if Session still valid update it
self.deezerConnect.authorize([DeezerConnectPermissionBasicAccess,
DeezerConnectPermissionManageLibrary,
DeezerConnectPermissionOfflineAccess
])
}
func saveToken(token:String,expirationDate:Date,userId:String)
{
print("[DeezerSession] Token. \(token) : Saved ")
print("[DeezerSession] Expire Date after. \(expirationDate) : Saved ")
print("[DeezerSession] User ID . \(userId) : Saved ")
defaults.setValue(token, forKey: "DEEZER_TOKEN_KEY")
defaults.setValue(expirationDate, forKey: "DEEZER_EXPIRATION_DATE_KEY")
defaults.setValue(userId, forKey: "DEEZER_USER_ID_KEY")
}
func deezerSessionDidConnect()
{
}
func retrieveTokenAndExpirationDate()
{
self.deezerConnect.accessToken = defaults.string(forKey: "DEEZER_TOKEN_KEY")
self.deezerConnect.expirationDate = defaults.object(forKey: "DEEZER_EXPIRATION_DATE_KEY") as? Date ?? Date()
self.deezerConnect.userId = defaults.string(forKey: "DEEZER_USER_ID_KEY")
print("[DeezerSession] Token. \(self.deezerConnect.accessToken) : Restored ")
print("[DeezerSession] Expire Date. \(self.deezerConnect.expirationDate) : Restored ")
print("[DeezerSession] User ID . \(self.deezerConnect.userId) : Restored ")
}
func isSessionValid()-> Bool
{
print("[DeezerSession] isSessionValid . \(self.deezerConnect.isSessionValid()) ")
return self.deezerConnect.isSessionValid()
}
func deezerDidLogin()
{
print("[DeezerSession] deezerDidLogin.")
self.saveToken(token : self.deezerConnect.accessToken,
expirationDate : self.deezerConnect.expirationDate ,
userId : self.deezerConnect.userId)
if self.callbackLogin != nil
{
self.callbackLogin!()
}
}
func deezerDidNotLogin()-> Bool
{
print("[DeezerSession] deezerDidNotLogin.")
return true
}
func deezerDidLogout()
{
print("[DeezerSession] deezerDidLogout.")
}
}
所有代表都没有触发 deezerDidLogout deezerDidNotLogin deezerDidLogin
最佳答案
SDK 提供DeezerSessionDelegate。根据文档,当用户成功登录时调用 deezerDidLogin。
因此,您可以从 DeezerConnect 实例中检索 token 、到期日期和用户标识符。您可以将它们保存到钥匙串(keychain)中。
下次用户启动应用程序时,您可以在 DeezerConnect 实例上重新设置这些值(从钥匙串(keychain)中检索它们)并通过发送 -[DeezerConnect isSessionValid ] 消息到同一个对象。如果 session 仍然有效,则不要要求用户再次登录。
显然,Keychain 是用于存储 token 和到期日期的建议位置。
更新
您能否修改创建单例实例的方式?
代替这段代码
//SHARED INSTANCE
static var instance: DeezerSession!
class func sharedInstance() -> DeezerSession {
if self.instance == nil
{
self.instance = DeezerSession();
}
return self.instance
}
就用
static let shared = DeezerSession()
事实上,这是在 Swift 中使用单例的推荐方式。
我认为您也不需要 init 方法中的 override。
关于ios - 在 Deezer iOS SDK 中恢复 session ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46089319/
这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下
我正在尝试解析一个文本文件,该文件每行包含可变数量的单词和数字,如下所示:foo4.500bar3.001.33foobar如何读取由空格而不是换行符分隔的文件?有什么方法可以设置File("file.txt").foreach方法以使用空格而不是换行符作为分隔符? 最佳答案 接受的答案将slurp文件,这可能是大文本文件的问题。更好的解决方案是IO.foreach.它是惯用的,将按字符流式传输文件:File.foreach(filename,""){|string|putsstring}包含“thisisanexample”结果的
1.错误信息:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)或者:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:TLShandshaketimeout2.报错原因:docker使用的镜像网址默认为国外,下载容易超时,需要修改成国内镜像地址(首先阿里
使用rails4,ruby2。我在rails配置中为我的cookiesession设置了30分钟的超时时间。问题是,如果我转到表单,让session超时,然后提交表单,我会收到此ActionController::InvalidAuthenticityToken错误。如何在Rails中优雅地处理这个错误?比如说,重定向到登录屏幕? 最佳答案 在您的ApplicationController:rescue_fromActionController::InvalidAuthenticityTokendoredirect_tosome_p
我去了这个website查看Rails5.0.0和Rails5.1.1之间的区别为什么5.1.1不再包含:config/initializers/session_store.rb?谢谢 最佳答案 这是删除它的提交:Setupdefaultsessionstoreinternally,nolongerthroughanapplicationinitializer总而言之,新应用没有该初始化器,session存储默认设置为cookie存储。即与在该初始值设定项的生成版本中指定的值相同。 关于
print"Enteryourpassword:"pass=STDIN.noecho(&:gets)puts"Yourpasswordis#{pass}!"输出:Enteryourpassword:input.rb:2:in`':undefinedmethod`noecho'for#>(NoMethodError) 最佳答案 一开始require'io/console'后来的Ruby1.9.3 关于ruby-为什么不能使用类IO的实例方法noecho?,我们在StackOverflow上
我正在尝试使用Sinatra中的重定向和session在网站周围传递一些数据。这是一个简化的示例,使用PrettyPrint进行调试:require'pp'require'rubygems'require'sinatra'enable:sessionsget'/'dosession[:foo]='12345'puts'session1'ppsessionredirectto('/redir')endget'/redir'doputs'session2'ppsession'helloworld'end查看Thin的输出,我看到:>>Listeningon0.0.0.0:4567,CTRL
我正在处理oauth1.0(twitter和flickr)。网站工作在80端口,oauth服务器工作在8080端口算法:向oauth服务器发送ajax请求以检查用户是否有有效的access_token如果用户没有access_token或access_token已过期,则打开授权窗口在oauth服务器的用户session中保存access_token发送分享数据到oauth服务器它使用sinatra+rack:session+rack::session::sequel+sqlite来存储session。它在每个响应中发送Set-Cookie:rack.session=id我正在使用2种
我正在尝试为使用omniauth-google-oauth2gem创建session编写测试。我是否需要将env["omniauth.auth"]变量与post:create一起传递?也许当我试图这样做时,我做错了。我得到的错误如下所示...Rake测试错误1)Error:SessionsControllerTest#test_should_get_create:NoMethodError:undefinedmethod`provider'fornil:NilClassapp/models/user.rb:6:in`from_omniauth'app/controllers/sessi
当使用rubyselenium驱动程序驱动chrome时,我得到/home/travis/.rvm/gems/ruby-2.6.2/gems/selenium-webdriver-3.141.5926/lib/selenium/webdriver/remote/response.rb:72:in`assert_ok':sessionnot创建:Chrome版本必须在70和73之间(Selenium::WebDriver::Error::SessionNotCreatedError)如何解决这个问题?降级chrome不是我想做的事。 最佳答案