我正在使用
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
最佳答案 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的推荐方法.
我认为你也不需要init方法中的覆盖.