- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在实现 Uber's Request Endpoint在我的 iOS (Swift) 应用程序中。请求 API/端点需要应用程序的用户身份验证,这里是 doc .
为此,我使用了这个 Oauth2.0 library
我做的是
在给定的安装说明的帮助下,成功地将库集成到我的项目 (xCode) 中。
在我的 AppDelegate 中
let uber_OAuth_Settings = [
"client_id": "XXXXXXX9vtKzobvXXXXXX",
"client_secret": "EXXXXXXXXyFUNCa_Wez6AXXXXXXXnrXtxus",
"authorize_uri": "https://login.uber.com/oauth/authorize",
"token_uri": "https://login.uber.com/oauth/token",
"redirect_uris": ["jamesappv2://oauth/callback"], // don't forget to register this scheme
] as OAuth2JSON
var oauth:OAuth2CodeGrant!
在我的 Appdelegate 方法 didFinishLaunchingWithOptions
中
oauth = OAuth2CodeGrant(settings: uber_OAuth_Settings)
oauth.viewTitle = "Uber Login Service" // optional
oauth.verbose = true // For Logs
不要忘记注册 url 方案,即 ("redirect_uris": ["jamesappv2://oauth/callback"]
)
转到您应用的目标 -> 信息选项卡 -> 网址类型 -> 单击 (+),附上图片
在 AppDelegate 中添加下面给出的方法并处理回调 Url
func application(application: UIApplication,
openURL url: NSURL,
sourceApplication: String?,
annotation: AnyObject?) -> Bool {
// you should probably first check if this is your URL being opened
var splitUrl = url.absoluteString!.componentsSeparatedByString(":")
if splitUrl[0] == ("jamesappv2") {
oauth.handleRedirectURL(url)
}
return true
}
现在在我的 viewController 中,我在 myBtnClick 上这样做
let appDelegate = UIApplication.sharedApplication().delegate as! AppDelegate
let url = appDelegate.oauth.authorizeURL()
UIApplication.sharedApplication().openURL(url)
appDelegate.oauth.onAuthorize = { parameters in
println("Did authorize with parameters: \(parameters)")
self.navigationController?.pushViewController(self.PersonalDriverUber_VC, animated: true)
//On Authorization Goto another ViewController using pushViewController of navigationcontroller Method
}
appDelegate.oauth.onFailure = { error in // `error` is nil on cancel
if nil != error {
println("Authorization went wrong: \(error!.localizedDescription)")
}
}
这是我的调试日志,我得到了有效的响应:
OAuth2: Handling redirect URL jamesappv2://oauth/callback?state=4B0EB812&code=0sXXXXXXTX7yEbS1XXXXXHuw
OAuth2: Successfully validated redirect URL
OAuth2: Authorizing against https://login.uber.com/oauth/token?state=38158941&grant_type=authorization_code&code=0sXXXXXXXX1jxTrdFQT9Huw&client_secret=EIXXXXXXXNCa_Wez6XXXXXw0BlnrXtxus&client_id=fXXXXXXXy2LOUo9vtKXXXXXQ1nUDO&redirect_uri=jamesappv2%3A%2F%2Foauth%2Fcallback
OAuth2: Exchanging code 0swNXXXXX7yXXXXXXdFQT9Huw with redirect jamesappv2://oauth/callback for token at Optional("https://login.uber.com/oauth/token")
OAuth2: Did receive access token: Dfq3XXXXXXuWgpaqFXXXXXXXgXW, refresh token: EmStT7FEXHRMlS8odPzs1nsha0ObjK
Did authorize with parameters: [token_type: Bearer, expires_in: 2592000, access_token: XXXXXXOZuWgXXXXXXXXuJYOmgXW, refresh_token: EXXXXXHRMlS8oXXXXXXXa0ObjK, scope: profile, last_authenticated: 1430121470]
注意我正在获取有效的 access_token
我卡在这里了
根据 DOCs在 STEP4 *USE BEARER TOKEN 中说
将 Authorization header 中响应中返回的 access_token 传递给 Bearer 类型,以代表用户发出请求。*
curl -H 'Authorization: Bearer YOUR_ACCESS_TOKEN' 'https://api.uber.com/v1/products?latitude=37.7759792&longitude=-122.41823'
我没听懂。我应该如何在带有 Bearer 类型的 Header 中传递 access_token?我做了如下
func callRequestAPI(url:String){
let request = appDelegate.oauth.request(forURL: NSURL(string:url)!)
request.HTTPMethod = "POST"
let postString = "product_id="+selectedUberProductId+"&start_latitude="+start_lat+"&start_longitude="+start_lng+"&end_latitude="+end_lat+"&end_longitude="+end_lng
println(postString)
let tempData: NSData = appDelegate.oauth.accessToken.dataUsingEncoding(NSUTF8StringEncoding)!
let base64LoginString = tempData.base64EncodedStringWithOptions(nil)
request.HTTPBody = postString.dataUsingEncoding(NSUTF8StringEncoding)
request.addValue("application/json", forHTTPHeaderField: "Content-Type")
request.addValue("application/json", forHTTPHeaderField: "Accept")
request.setValue("Bearer \(base64LoginString)", forHTTPHeaderField: "Authorization")
let session = NSURLSession.sharedSession()
let task = session.dataTaskWithRequest(request) { data, response, error in
if error != nil {
println("error=\(error)")
return
}
println("response = \(response)")
let responseString = NSString(data: data, encoding: NSUTF8StringEncoding)
println("responseString = \(responseString)")
}
task.resume()
}
但我得到了以下回应
response = <NSHTTPURLResponse: 0x1a284b50> { URL: https://sandbox-api.uber.com/v1/requests } { status code: 401, headers {
"Content-Length" = 75;
"Content-Type" = "application/json";
Date = "Mon, 27 Apr 2015 10:22:01 GMT";
Server = nginx;
"Strict-Transport-Security" = "max-age=31536000; includeSubDomains; preload";
"x-uber-app" = "uberex-sandbox";
"x-xss-protection" = "1; mode=block";
} }
responseString = Optional({"message":"Invalid OAuth 2.0 credentials provided.","code":"unauthorized"})
最佳答案
我终于做到了:)
我改变了下面的方法,它起作用了
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]
let request = appDelegate.oauth.request(forURL: NSURL(string:url)!)
request.setValue("application/json; charset=utf-8", forHTTPHeaderField: "Content-Type")
request.HTTPMethod = "POST"
var err: NSError?
request.HTTPBody = NSJSONSerialization.dataWithJSONObject(params, options: NSJSONWritingOptions.allZeros, error: &err)
let task = session.dataTaskWithRequest(request) {
data, response, error in
if let httpResponse = response as? NSHTTPURLResponse {
if httpResponse.statusCode != 202 {
println("response was not 202: \(response)")
return
}
}
if (error != nil) {
println("error submitting request: \(error)")
return
}
// handle the data of the successful response here
var result = NSJSONSerialization.JSONObjectWithData(data, options: NSJSONReadingOptions.allZeros, error: nil) as! NSDictionary
println(result)
if let request_id: String = result["request_id"] as? String{
println(request_id)
}
if let driver: String = result["driver"] as? String{
println(driver)
}
if let eta: Int = result["eta"] as? Int{
println(eta)
}
if let location: String = result["location"] as? String{
println(location)
}
if let status: String = result["status"] as? String{
println(status)
}
if let surge_multiplier: Int = result["surge_multiplier"] as? Int{
println(surge_multiplier)
}
if let vehicle: String = result["vehicle"] as? String{
println(vehicle)
}
}
task.resume()
}
这是我得到的响应,我上面的方法也给出了解析
{
driver = "<null>";
eta = 15;
location = "<null>";
"request_id" = "ea39493d-b718-429f-8710-00a34dcdaa93";
status = processing;
"surge_multiplier" = 1;
vehicle = "<null>";
}
享受
关于ios - Uber 在 ios Swift 中提供了无效的 OAuth 2.0 凭据 Uber 身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29895238/
我需要用 90% 的优步功能制作我自己的应用程序我可以使用 uber api 构建自己的后端服务吗? 我的意思是创建我自己的服务器端并使用 super 算法,司机和客户向我注册,而不是 uber 最佳
我们正在开发一个应用程序,我们需要用我们自己的信用卡为不同的用户支付费用。有点 Uber 业务,但无需手动添加帐户。 Uber API 可以吗? 最佳答案 不幸的是,如今在 Uber API 中无法为
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 5 年前。 Improv
我正在编写一个使用 uber API 的 iOS 应用程序。我试图通过 Uber API 获取当前事件的 request_id,但是对/v1/requests 的 GET 请求不起作用。从文档看来,这
我已将我的应用程序配置为接收沙箱请求 api 状态更改的回调,但我尚未收到对我的 webhook url 的任何调用。我已经能够用帖子测试我的网络钩子(Hook)网址并且它有效,所以我不认为它的网址是
我正在向https://sandbox-api.uber.com/v1/requests提出请求使用我的帐户的不记名 token (这是 Uber 应用程序的管理员)。 当我提出请求时,我收到 401
当我尝试在沙盒中请求乘车收据时,回复似乎总是 9 美元。金额我不太在意,但货币是有问题的。该请求是通过 API(沙盒)发出的,估计和实际乘车请求都以本地货币返回票价金额,可能是也可能不是美元。有没有办
我正在关注 Uber Eats API 文档,但遇到了问题。我希望它与我的销售点网络应用程序一起使用。 文档说: To generate a client credentials token, ret
根据 Uber 文档,应通过以下方式推荐新用户:“https://m.uber.com/sign-up?client_id=YOUR_CLIENT_ID ” 那么,有没有办法通过以下方式引用使用 oA
我只是测试新的请求端点,想知道我可以从 Map 请求中获得什么返回结果? https://developer.uber.com/v1/endpoints/#request-map 我目前正在使用沙箱进
我正在尝试使用 Auth 2.0 对 Uber REST API 进行身份验证,但范围似乎存在问题。一旦我指定了一个范围(甚至是非特权范围),/authorize 请求就会失败并显示“无效范围”。如果
我使用 uber sdk ( https://github.com/uber/rides-ios-sdk) 创建了一个自定义应用程序。我还有“连接”按钮和 singup 选项,我在登录/注册期间使用“
我正在使用适用于 iOS 的优步 SDK。如何在 Swift 中实现自定义优步叫车请求按钮?我不想使用优步在他们的文档中使用的标准按钮。我想为它设计自己的用户界面。 Reference 最佳答案 您可
我在我的应用程序中集成了“用优步乘车”按钮。我觉得,如果我显示预计到达时间和目的地的预估价格,对用户来说会更方便。我怎样才能做到这一点?我现在正在遵循本指南:https://github.com/ub
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 5 年前。 Improve this qu
我知道我可以通过创建 2 个模块来实现它,但只是想知道是否可以在一个模块中做到这一点?谢谢 最佳答案 Maven Shade 插件,如果运行 shade 目标,默认会生成两个 JAR: your-ar
我在这里关注深度链接的文档: https://developer.uber.com/v1/deep-linking/#launching-the-uber-mobile-site 好吧,我可以打开网站
对于 Uber 登录,我在 Android 手机端遵循“单点登录”登录机制,但由于刷新 token ,我遇到了问题。刷新 token 我们在 AccessToken 类中获得的(30 个字符)我们将其
Uber API v1.2 Documentation GET /estimates/price在 surge_multiplier 的定义中包含歧义支持: 它被声明为响应的参数之一 但是 未在响应示
我正在集成优步乘车请求 API。我成功验证了 uber 帐户。我可以从 uber api 获取用户历史记录和用户配置文件,但我没有获取 v1.2/requests/estimate。但是当我请求乘车时
我是一名优秀的程序员,十分优秀!