【问题标题】:Uber Authentication failed "HTTP Status 401: Unauthorized, Response: {"error": "invalid_client"}"Uber 身份验证失败“HTTP 状态 401:未经授权,响应:{“error”:“invalid_client”}”
【发布时间】:2015-07-16 08:56:08
【问题描述】:

我正在使用 this 库进行 Uber 身份验证

https://developer.uber.com/v1/auth/

我已经这样做了

func doOAuthUber(){

let oauthswift = OAuth2Swift(
    consumerKey:    "fXfXXXXXXXUo9vtKzobXXXXXUDO",
    consumerSecret: "e5XXXXXXXq2w63qz9szEx7uXXXXXXo03W",
    authorizeUrl:   "https://login.uber.com/oauth/authorize",
    accessTokenUrl: "https://login.uber.com/oauth/token",
    responseType:   "code"
)

var originalString = "jamesappv2://oauth/callback"
var encodedCallBackUrl = originalString.stringByAddingPercentEncodingWithAllowedCharacters(.URLHostAllowedCharacterSet())

println("encodedCallBackUrl: \(encodedCallBackUrl)")


let state: String = ""
oauthswift.authorizeWithCallbackURL( NSURL(string: encodedCallBackUrl!)!, scope: "request%20history", state: state, success: {
    credential, response in

    println(credential.oauth_token)
    self.personalDriverLoader.stopAnimating()



    }, failure: {(error:NSError!) -> Void in

        self.personalDriverLoader.stopAnimating()
        println(error.localizedDescription)
})

}

但收到此回复 HTTP 状态 401:未经授权,响应:{"error": "invalid_client"}

我已经三次检查我的 client_id (consumerKey) 和 secret (consumerSecret) 是否正确。 我在这里做错了什么

更新:1

这是有线的,我将 responseType: "code" 更改为 responseType: "token" 并且它工作得到了我的访问令牌。但我现在遇到了另一个问题

现在每当我尝试拨打request endpoint api

使用下面的代码

@IBAction func btnRequestUberdidClicked(sender: AnyObject) {

    self.callRequestAPI("https://sandbox-api.uber.com/v1/requests")

}

func callRequestAPI(url:String){

    var configuration = NSURLSessionConfiguration.defaultSessionConfiguration()
    var session = NSURLSession(configuration: configuration)

    let params:[String: AnyObject] = [
                "product_id" : selectedUberProductId,
                "start_latitude" : start_lat,
                "start_longitude" : start_lng,
                "end_latitude" : end_lat,
                "end_longitude" : end_lng]



    appDelegate.oauthswift.client.post(url, parameters: params,
    success: { data, response in

    let dataString = NSString(data: data, encoding: NSUTF8StringEncoding)


         println("Success")

                    println(data)

                    println(response)


        }, failure: {(error:NSError!) -> Void in

                         println("Error")

                    println(error)
    })


}

我收到此回复

Error Domain=NSURLErrorDomain Code=401 "HTTP Status 401: Unauthorized, Response: {"message":"Invalid OAuth 2.0 credentials provided.","code":"unauthorized"}" UserInfo=0x1c563220 {NSLocalizedDescription=HTTP Status 401: Unauthorized, Response: {"message":"Invalid OAuth 2.0 credentials provided.","code":"unauthorized"}, Response-Headers=<CFBasicHash 0x1c578c40 [0x35305710]>{type = immutable dict, count = 7,
entries =>
    1 : x-xss-protection = <CFString 0x1ae2fc60 [0x35305710]>{contents = "1; mode=block"}
    4 : Server = <CFString 0x1acc24c0 [0x35305710]>{contents = "nginx"}
    5 : Content-Type = <CFString 0x1c4d0020 [0x35305710]>{contents = "application/json"}
    6 : Content-Length = <CFString 0x1c4b70b0 [0x35305710]>{contents = "75"}
    8 : Date = <CFString 0x1c4ed4b0 [0x35305710]>{contents = "Wed, 06 May 2015 12:46:51 GMT"}
    10 : Strict-Transport-Security = <CFString 0x1c225cb0 [0x35305710]>{contents = "max-age=31536000; includeSubDomains; preload"}
    11 : x-uber-app = <CFString 0x1c49a6b0 [0x35305710]>{contents = "uberex-sandbox"}
}
}

【问题讨论】:

  • Uber API 需要 OAuth2,但您使用的是 OAuth1 格式的库。检查github.com/dongri/OAuthSwift#examples。在Uber API doc 中查看,身份验证是在三个 步骤中完成的,而不是一个。 :)
  • @EricD。感谢您的回复。如何使用这个库来使用 Oauth2。让我知道这有什么问题。你可以看到我使用过 OAuth2Swift
  • 您使用了正确的OAuth2Swift 对象,在其中您使用了错误的声明格式。查看 OAuthSwift 页面上的 last 示例,其中不应该有任何 accessTokenUrl。得到此响应后,请按照 redirect 进行操作,然后最终获得令牌。 :)
  • 这是有线的,我将 responseType: "code" 更改为 responseType: "token" 并且它起作用了 (o0) 。得到了我的访问令牌。但我现在遇到了另一个问题
  • @EricD。查看我的更新

标签: ios iphone swift authentication uber-api


【解决方案1】:

您必须尽可能修改库,并能够打印从 Uber 返回的身份验证代码。我在使用 Objective C 进行 Uber 身份验证时遇到了类似的问题,然后我从我的日志中意识到 Uber 正在将#_ 附加到授权代码中。因此,当此代码用于获取访问令牌时,它会失败,(401) unauthorised error 只是说身份验证代码无效,确实如此。

见下图。

所以最终我不得不从身份验证代码中删除#_,然后才能使用它来获取访问令牌。

AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
NSDictionary *params1 = @{@"client_secret":UBER_CLIENT_SECRET,
                          @"client_id":UBER_CLIENT_ID,
                          @"grant_type":@"authorization_code",
                          @"redirect_uri":UBER_REDIRECT_URL,
                          @"code":[app.uberAuthCodeStr stringByReplacingOccurrencesOfString:@"#_" withString:@""]};
                    //******* THE FIX IS HERE ON THIS LINE ^^^

[manager POST:@"https://login.uber.com/oauth/v2/token" parameters:params1 success:^(AFHTTPRequestOperation *operation, id responseObject){
    NSLog(@"JSON: %@", responseObject);
    //
    app.uberBearerAccess_token = [responseObject valueForKey:@"access_token"];
    app.uberBearerRefresh_token = [responseObject valueForKey:@"refresh_token"];
    NSLog(@"Bearer AccessToken = %@ ",app.uberBearerAccess_token);
    // Save access token to user defaults for later use.
    NSUserDefaults * defaults = [NSUserDefaults standardUserDefaults];
    NSNumber *seconds = [responseObject objectForKey:@"expires_in"];
    NSDate *expiryDate = [[NSDate date] dateByAddingTimeInterval:seconds.intValue];
    [defaults setObject:expiryDate forKey:KEY_UBER_TOKEN_EXPIRE_DATE];
    [defaults setObject:app.uberBearerAccess_token forKey: KEY_UBER_TOKEN];
    [defaults setObject:app.uberBearerRefresh_token forKey: KEY_UBER_REFRESH_TOKEN];
     [defaults setObject:app.uberAuthCodeStr forKey: KEY_UBER_AUTH_CODE];
    [defaults synchronize];
    loginView.hidden = YES;
    [self goUberChat];
    //
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
    NSLog(@"Error: %@':%@", error,params1);
    [ProgressHUD dismiss];
}];

希望这对您或遇到类似问题的任何人有所帮助。

【讨论】:

    【解决方案2】:

    试试这个调用 Uber Api

     NSString *string=[NSString stringWithFormat:@"https://api.uber.com/v1/products"];
        NSURL *url=[NSURL URLWithString:string];
        AFHTTPSessionManager *manager=[[AFHTTPSessionManager alloc]initWithBaseURL:url];
        NSDictionary *parameters = @{@"server_token":@"Your token",@"latitude":@"latitude",@"longitude":@"longitude",
        [manager GET: parameters:parameters progress:nil success:^(NSURLSessionTask *task,id responseObject){
        } failure:^(NSURLSessionTask *operation , NSError *error)
    }];
    

    【讨论】:

    • 虽然此代码可以回答问题,但提供有关它为什么和/或如何回答问题的额外上下文将显着提高其长期价值。请edit你的答案添加一些解释。
    猜你喜欢
    • 1970-01-01
    • 2013-07-17
    • 2013-01-01
    • 1970-01-01
    • 2018-07-09
    • 2019-10-09
    • 2020-08-12
    • 2012-06-30
    • 2012-11-27
    相关资源
    最近更新 更多