用于将视频(和属性)上传到vimeo的RESTful机制

时间:2016-03-24 22:03:05

标签: swift rest alamofire vimeo-api vimeo-ios

将视频上传到Vimeo的过程与为Youtube定义的过程非常相似,但最多只能达到一个点。下面我将介绍工作的步骤,并概述的上一个视频上传步骤:

当我们传递以下参数以触发用户身份验证时,Vimeo上传舞会开始:

let authPath:String = "\(url_vauth)?response_type=\(response_type)&client_id=\(client_id)&redirect_uri=\(redirect_uri)&state=\(state)&scope=upload"

if let authURL:NSURL = NSURL(string: authPath) {
  let request = NSURLRequest(URL: authURL)
  webView.loadRequest(request)  // opens a webpage in a webUIView

  // once credentials are entered, google redirects back with the above uri + a temporary code
  // we will exchange later for a token

  // within AppDelegate, we have defined a way to handle this uri, which is to call
  // processOAuthStep1Response(url)

然后,我们处理返回的响应以提取授权码

let components = NSURLComponents(URL: url, resolvingAgainstBaseURL: false)
var auth_code:String!
// the block below extracts the text that follows "code" in the return url

if let queryItems = components?.queryItems {
  for queryItem in queryItems { // step through each part of url
    if queryItem.name.lowercaseString == "code" {
      auth_code = queryItem.value
      break
    } //  end of if queryItem.name.lowercaseString
  } // end of for
} // if let queryItems

使用此授权码,我们会生成令牌

  let getTokenPath:String = url_token
  let grant_type = "authorization_code"
  let header_plain = "\(client_id):\(client_secret)"
  let string_plain = header_plain.dataUsingEncoding(NSUTF8StringEncoding)
  let string_base64 = (string_plain?.base64EncodedStringWithOptions(NSDataBase64EncodingOptions(rawValue: 0)))! as String
  let headers = ["Authorization": "basic \(string_base64)"]  // note that string_base64 really needs to be in base64!
  //print ("...header is: \(string_base64)")
  let tokenParams = ["grant_type": grant_type, "code": receivedCode, "redirect_uri": redirect_uri, "scope": "public"]
  let request = Alamofire.request(.POST, getTokenPath, parameters: tokenParams, encoding: .URL, headers: headers)

我们使用此令牌生成票证

request(.POST, url_getticket, parameters: ticketParams , encoding: .URL, headers: headers).responseJSON { response  in
  //print(response)
  switch response.result {
  case .Success(let data):
    let json = JSON(data)
    print (json)
    let myticket = json["ticket_id"].stringValue
    //let usage = json[("upload_quota")].stringValue
    let htmlform = json[("form")].stringValue
    let uploadlink = json[("upload_link_secure")].stringValue
    print("......ticket is \(myticket)")
    print("......form is \(htmlform)")
    print("......upload link is \(uploadlink)")
  case .Failure(let error):
    print("Request failed with error: \(error)")
  } // end of switch

最后(这就是停止戛然而止的地方)我们应该使用此票证向Vimeo发出 POST 请求。问题是这张票是嵌入在一个html表单中,实际上是向Vimeo发送上传请求...对于我试图实现这一点的iOS平台来说不是很有用。理想情况下,我希望通过像这样的上传调用实现Alamofire:

  let headers = ["Authorization": "Bearer \(token)"]
  upload(
      .POST,
      "https://1511923767.cloud.vimeo.com/upload?ticket_id=#######&video_file_id=####&signature=####&v6=1&redirect_url=https%3A%2F%2Fvimeo.com%2Fupload%2Fapi%3Fvideo_file_id%3D498216063%26app_id%3D70020%26ticket_id%####%26signature%######", 
      headers: headers,
      multipartFormData: { multipartFormData in
        multipartFormData.appendBodyPart(data: videodata, name: "video", fileName: "bagsy.m4v", mimeType: "application/octet-stream")
      },
      encodingCompletion: { encodingResult in
        switch encodingResult {
        case .Success(let upload, _, _):
          upload.progress { bytesWritten, totalBytesWritten, totalBytesExpectedToWrite in
            dispatch_async(dispatch_get_main_queue()) {
              let percent = (Float(totalBytesWritten) / Float(totalBytesExpectedToWrite))
              //progress(percent: percent)
              print ("................\(percent)")
            }
          }
          upload.validate()
          upload.responseJSON { response in
            print(response)
            callback(true)
          }
        case .Failure(_):
          callback(false)
        }

    })

不用说,上面的代码块不起作用。任何指导都将非常感激。

2 个答案:

答案 0 :(得分:3)

考虑使用官方Vimeo iOS Upload SDK。我们大约2周前公布了它。它是一个Swift库,用于处理将视频文件上传到Vimeo服务器。它使用后台配置的NSURLSession执行此操作(因此无论您的应用是在前台还是后台,上传都会继续)。如果你有任何疑问,请告诉我们。注意:我是该图书馆的一位作者,我在Vimeo工作。

VimeoUpload自述文件非常强大,应该沟通您需要知道的所有内容。生菜知道你是否还有其他问题,或者随时提出拉动请求。

答案 1 :(得分:0)

从不在上传中手动使用故障单。您应该始终使用API​​提供的url或html。

如果您看到HTML,那是因为您没有提供“type”参数。我们默认使用如下所述的简单POST上传系统:https://developer.vimeo.com/api/upload/videos#simple-http-post-uploading

如果你提供“type = streaming”,Vimeo会返回一个“complete_url”,你必须在执行流媒体上传后调用,如下所述:https://developer.vimeo.com/api/upload/videos#resumable-http-put-uploads