2016-01-13 192 views
0

我正在尝试对AtTask RESTful API进行Get请求以获取1000个项目对象。 ATask API documentation给出了一些关于如何做到这一点的提示。我需要对我要请求的对象数进行分页。想象一下,我需要抓取过去7天内可用的任何对象,但我不知道对象的确切数量,因此我如何更改以下代码来实现此目的,所以我不知道应该是什么值我的分页,我不知道,如果我可以递归发送Get请求,直到所有的数据被提取。通过AtTask RESTful API获取和分页所有数据

public JToken Search(ObjCode objcode, object parameters, int limit = 100) 
      { 
      VerifySignedIn(); 
      string[] p = parameterObjectToStringArray(parameters, "sessionID=" + SessionID); 
      JToken json = null; 
      if (limit > 100) 
      { 
       json = client.DoGet(string.Format("/{0}/search?$$LIMIT={1}", objcode,limit),limit,p); 
      } 
      else 
      { 
       json = client.DoGet(string.Format("/{0}/search", objcode),limit,p); 
      } 

      return json; 
      } 


public JToken DoGet(string path,int limit = 100 ,params string[] parameters) 
     { 
      return DoRequest(path,limit ,parameters); 
     } 

public JToken DoRequest(string path,int limit, params string[] parameters) 
     { 
      if (!path.StartsWith("/")) 
      { 
       path = "/" + path; 
      } 
      string fullUrl = url + path + ToQueryString(parameters,limit); 

      if (DebugUrls) Console.WriteLine("Requesting: {0}", fullUrl); 

      WebRequest request = HttpWebRequest.CreateDefault(new Uri(fullUrl)); 
      using (WebResponse response = request.GetResponse()) 
      { 
       using (Stream responseStream = response.GetResponseStream()) 
       { 
        return ReadResponse(responseStream); 
       } 
      } 
     } 

private string ToQueryString(string[] parameters, int limit = 100) 
    { 
     StringBuilder sb = new StringBuilder(); 
     parameters.ToList().ForEach(s => sb.Append(s).Append("&")); 
     if (sb.Length > 0) 
     { 
      sb.Remove(sb.Length - 1, 1); 
     } 
     return limit > 100 ? "&" + sb : "?" + sb; 
    } 

回答

2

您需要首先调用COUNT来获取您正在处理的对象数量的值。 这与/ search相同,但使用/ count而不是搜索。

例如

GET /attask/api/v4.0/proj/count?status=cur 

你可以再通过使用$$第一页和拉你的结果。

你的代码看起来comething这样

public JToken Search(ObjCode objcode, object parameters, int limit = 100) 
     { 
     VerifySignedIn(); 
     string[] p = parameterObjectToStringArray(parameters, "sessionID=" + SessionID); 
     JToken json = null; 
     JToken count = null; 

     count = client.DoGet(string.Format("/{0}/count", objcode),limit,p); 

     for(int i=0; i<count; i+limit){ 
      if (limit > 100) 
      { 
       json = client.DoGet(string.Format("/{0}/search?$$LIMIT={1}&$$FIRST={2}", objcode,limit,i),limit,p); 
      } 
      else 
      { 
       json = client.DoGet(string.Format("/{0}/search&$$FIRST={1}", objcode,i),limit,p); 
      } 

      return json; 
     } 

    } 

这些信息可以发现https://developers.workfront.com/api-docs/#PaginatedResponses

相关问题