我正在使用Deezer iOS SDK,在Swift中一切顺利,除了会话,在Android SDK中存在一个方法.restoreSession()
,以避免每次弹出用户登录,但我看不到它在iOS SDK中,所以每次会话过期时,用户都会弹出以使用hi的Deezer帐户再次登录,无论如何在iOS SDK中保存或恢复会话?
这是Android恢复会话代码:
// 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登录时,我没有收到代理人的通知
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
答案 0 :(得分:1)
SDK提供DeezerSessionDelegate
。根据文档,当用户成功登录时会调用deezerDidLogin
。
因此,您可以从DeezerConnect
实例检索令牌,到期日期和用户标识符。您可以将它们保存到钥匙串中。
用户下次启动应用程序时,您可以在DeezerConnect
实例上设置这些值(从Keychain中检索它们)并通过向其发送 - [DeezerConnect isSessionValid]
消息来测试其有效性宾语。如果会话仍然有效,请不要让用户再次登录。
显然,钥匙串是建议的地方,以存储令牌和到期日期。
有关详细信息:iOS Session Management
<强>更新强>
您是否可以修改单例实例的创建方式?
而不是这段代码
//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中使用singleton的推荐方法。
我认为您也不需要override
方法中的init
。