ios - 如何获取访问令牌?

时间:2013-05-02 07:13:40

标签: ios objective-c access-token

我正在关注this link以获取访问令牌,但有些内容泄露在以下代码中,特别是在网址和内容中。

 -(void)connectionDidFinishLoading:(NSURLConnection *)connection

 {

  if(_data)
  {
    NSString* content = [[NSString alloc] initWithData:_data
                                              encoding:NSUTF8StringEncoding];

    [_data release];
    _data = nil;

    NSString *jsString = @"<script type='text/javascript'>\
    window.external =\
    {\
    'Notify': function(s) { document.location = 'acs://settoken?token=' + s; },\
    'notify': function(s) { document.location = 'acs://settoken?token=' + s; }\
    }\
    </script>";

   //Here appending the above javascript with content

    content = [jsString stringByAppendingString:content];

    NSURL *url = [[NSURL alloc] initWithString:@"https://converse.accesscontrol"];

    [webView loadHTMLString:content baseURL:url];
   }
   }

登录Gmail或Yahoo时,会触发以下代码,然后检查网址,但此处(如果条件失败)。如果您无法理解,我正在尝试提问。请参阅上面给出的链接。

 - (BOOL)webView:(UIWebView *)webView
  shouldStartLoadWithRequest:(NSURLRequest *)request
 navigationType:(UIWebViewNavigationType)navigationType

{

_url = [[NSURL alloc] initWithString:@"https://converse.accesscontrol.windows"];

  if(_url)
  {

    if([_url isEqual:[request URL]])
    {
        return YES;
    }

    [_url release];
  }

  _url = [[request URL] retain];
   NSString* scheme = [_url scheme];

  if([scheme isEqualToString:@"acs"])
   {
    // parse the JSON URL parameter into a dictionary
    NSDictionary* pairs = [self parsePairs:[_url absoluteString]];
    if(pairs)
    {
        WACloudAccessToken* accessToken;
        accessToken = [[WACloudAccessToken alloc] initWithDictionary:pairs];
        [WACloudAccessControlClient setToken:accessToken];

        [self dismissModalViewControllerAnimated:YES];
    }

    return NO;
   }

   [NSURLConnection connectionWithRequest:request delegate:self];

   return NO;

  }

有什么想法吗?提前谢谢。

1 个答案:

答案 0 :(得分:0)

你成功获得了设备令牌.....

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
    
    
  
    [[UIApplication sharedApplication] registerForRemoteNotificationTypes:(UIRemoteNotificationTypeAlert | UIRemoteNotificationTypeSound | UIRemoteNotificationTypeBadge)];
   [[UIDevice currentDevice] beginGeneratingDeviceOrientationNotifications];

}

- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
    
    self.strToken = [[[[deviceToken description]
                       stringByReplacingOccurrencesOfString: @"<" withString: @""]
                      stringByReplacingOccurrencesOfString: @">" withString: @""]
                     stringByReplacingOccurrencesOfString: @" " withString: @""];
    
    NSLog(@"%@",deviceToken);
}


- (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error {
    NSString *str = [NSString stringWithFormat: @"Error: %@", error];
   
}

- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo {
    
    NSLog(@"user info  %@",userInfo);
    UIApplicationState state = [application applicationState];
    if (state == UIApplicationStateActive) {
        NSString *cancelTitle = @"OK";
        //NSString *showTitle = @"Show";
        NSString *message = [[userInfo valueForKey:@"aps"] valueForKey:@"alert"];
        UIAlertView *alertView = [[UIAlertView alloc] initWithTitle:nil
                                                            message:message
                                                           delegate:self
                                                  cancelButtonTitle:cancelTitle
                                                  otherButtonTitles: nil];
        [alertView show];
        [alertView release];
        
        
    } 
   else {
        //Do stuff that you would do if the application was not active
    }
}