【问题标题】:How to save LinkedIn Access Token using iOS SDK?如何使用 iOS SDK 保存 LinkedIn 访问令牌?
【发布时间】:2013-09-05 12:03:29
【问题描述】:

我在我的 iOS 应用程序中使用 LinkedIn。我想保存访问令牌以备将来使用。

令牌是非属性类型,不能直接保存在NSUserDefaults中。 我尝试为此使用NSKeyedArchiver,但我得到了输出:

Token===oauth_token "(null)" oauth_token_secret "(null)" oauth_verifier "(null)"

令牌中的文本即将到来,但值即将到来。

代码 sn-p 1

-(void)saveData :(LOAToken *)token
{
    NSFileManager *filemgr;
    NSString *docsDir;
    NSArray *dirPaths;

    filemgr = [NSFileManager defaultManager];

    // Get the documents directory
    dirPaths = NSSearchPathForDirectoriesInDomains(
                                                   NSDocumentDirectory, NSUserDomainMask, YES);

    docsDir = [dirPaths objectAtIndex:0];

    // Build the path to the data file
    NSString *dataFilePath = [[NSString alloc] initWithString: [docsDir
                                                                stringByAppendingPathComponent: @"data.archive"]];

    [NSKeyedArchiver archiveRootObject:
     token toFile:dataFilePath];
}


-(LOAToken *)GetToken
{
    NSFileManager *filemgr;
    NSString *docsDir;
    NSArray *dirPaths;

    filemgr = [NSFileManager defaultManager];

    // Get the documents directory
    dirPaths = NSSearchPathForDirectoriesInDomains(
                                                   NSDocumentDirectory, NSUserDomainMask, YES);

    docsDir = [dirPaths objectAtIndex:0];

    // Build the path to the data file
    NSString *dataFilePath = [[NSString alloc] initWithString: [docsDir
                                                                stringByAppendingPathComponent: @"data.archive"]];

    // Check if the file already exists
    if ([filemgr fileExistsAtPath: dataFilePath])
    {
        LOAToken *token;

        token = [NSKeyedUnarchiver
                     unarchiveObjectWithFile: dataFilePath];

        return token;
    }

    return NULL;
}

我也试过这样保存,但结果是一样的:

Token===oauth_token "(null)" oauth_token_secret "(null)" oauth_verifier "(null)"

代码 sn-p 2

NSData *myEncodedObject = [NSKeyedArchiver archivedDataWithRootObject:self.accessToken];
    NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
    [defaults setObject:myEncodedObject forKey:@"myEncodedObjectKey"];
    [defaults synchronize];

   NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
   NSData *myEncodedObject = [defaults objectForKey:@"myEncodedObjectKey"];
            LOAToken *obj = (LOAToken *)[NSKeyedUnarchiver unarchiveObjectWithData: myEncodedObject];

我的编码有什么问题吗?或者Access Token需要一些特殊的技术来保存?请指教。

【问题讨论】:

  • 您可以将访问令牌直接保存到用户默认值中。无需存档
  • 感谢您的回复。当我直接保存到默认值时,我收到消息 [NSUserDefaults setObject:forKey:]: Attempt to insert non-property value '' of class 'OAToken'。请注意,属性列表中的字典和数组也必须只包含属性值。
  • 不保存 OAToken 对象像我一样直接保存响应正文,当您想使用访问令牌时,使用 reponseBody 将其初始化并使用访问令牌 'self.accessToken = [[NSUserDefaults standardUserDefaults] valueForKeyPath: @"accessToken"]; [[OAToken alloc] initWithHTTPResponseBody:self.accessToken]'
  • 你在使用 oAuth 2.0 吗?
  • OAuth 1.0。你有OAuth 2.0的样本吗?

标签: ios linkedin nsuserdefaults social-networking


【解决方案1】:

我就是这样保存的。它对我有用。希望它有所帮助

- (void)accessTokenResult:(OAServiceTicket *)ticket didFinish:(NSData *)data
{
    NSDictionary *dict;
    NSString *responseBody = [[NSString alloc] initWithData:data
                                               encoding:NSUTF8StringEncoding];
    BOOL problem = ([responseBody rangeOfString:@"oauth_problem"].location != NSNotFound);
   if (problem)
   {
        DLog(@"Request access token failed.");
        DLog(@"%@",responseBody);
        dict = [NSDictionary dictionaryWithObjectsAndKeys:@"0",@"success",@"Request access token failed.",@"reason", nil];
   }
   else
   {
       self.accessToken = [[OAToken alloc] initWithHTTPResponseBody:responseBody];
       [[NSUserDefaults standardUserDefaults] setObject:responseBody forKey:@"accessToken"];//save here
       [[NSUserDefaults standardUserDefaults] setObject:[NSDate date] forKey:@"TokenRefreshDate"];//save here
       [[NSUserDefaults standardUserDefaults] synchronize];
       dict = [NSDictionary dictionaryWithObjectsAndKeys:@"1",@"success",@"Login Successful",@"reason", nil];
   }
   // Notify parent and close this view
   [[NSNotificationCenter defaultCenter] postNotificationName:@"loginViewDidFinish" object:self userInfo:dict];
   [self dismissViewControllerAnimated:YES completion:^{

   }];
 }

以这种方式使用保存的 responseBody

self.accessToken = [[NSUserDefaults standardUserDefaults] valueForKeyPath:@"accessToken"];
NSURL *url = [NSURL URLWithString:@"http://api.linkedin.com/v1/people/~/connections:(id,first-name,last-name,headline,maiden-name,picture-url,formatted-name,location,positions,public-profile-url,specialties,num-connections,industry)"];

OAMutableURLRequest *request = [[OAMutableURLRequest alloc] initWithURL:url
                                                                   consumer:self.consumer
                                                                      token:[[OAToken alloc] initWithHTTPResponseBody:self.accessToken]
                                                                   callback:nil
                                                          signatureProvider:nil];

[request setValue:@"json" forHTTPHeaderField:@"x-li-format"];
OADataFetcher *fetcher = [[OADataFetcher alloc] init];
[fetcher fetchDataWithRequest:request
                         delegate:self
                didFinishSelector:@selector(connectionsApiCallResult:didFinish:)
                  didFailSelector:@selector(connectionsApiCallResult:didFail:) withId:0];

希望这次我清楚

【讨论】:

  • 感谢您的回答。下次我们进入应用程序时它会在调用时提供访问令牌:self.accessToken = [[OAToken alloc] initWithHTTPResponseBody:responseBody];因为我们正在保存响应正文(字符串)。
  • 从下一次开始,你应该从 NSUserDa]efaults 中获取 responseBody 字符串,然后创建 OAToken 对象。responseBody 将被存储,直到你卸载你的应用程序为止
  • 让我澄清一下名称 accessToken 冲突。 self.accessToken = [[OAToken alloc] initWithHTTPResponseBody:responseBody]; 在这一行 accessToken 是 OAToken 的实例,self.accessToken = [[NSUserDefaults standardUserDefaults] valueForKeyPath:@"accessToken"]; 在这一行 accessToken 是 NSString。
  • 我想我赶时间了。我已经有了访问令牌,那么为什么我们要再次请求 OAMutableURLRequest。
  • 我们是否需要像第一次出现登录对话框时那样获取访问令牌并使用访问令牌进行请求。更多提示。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2015-10-11
  • 2017-01-07
  • 2013-07-24
  • 1970-01-01
  • 2015-07-16
  • 2016-09-04
  • 1970-01-01
相关资源
最近更新 更多