C#使HttpWebResponse等到收到响应而不是接收HTTP 400错误

时间:2017-05-01 19:47:42

标签: c# httpwebresponse

我正在尝试使用他们的API访问Adobe的Datawarehouse报告。它的工作方式是首先使用可用的指标和您想要它的维度来形成JSON。一切正常。但是我确实遇到了这个问题。每当我请求超过3到4个维度时,报告生成的时间就会更长。我需要 HttpWebResponse 等到它完成后再转到下一行。下面是我根据github的一个例子构建的示例代码。

class Program 
{

    protected static string JSONFolder = System.Configuration.ConfigurationManager.AppSettings["JSONFolder"];
    protected static string USERNAME = System.Configuration.ConfigurationManager.AppSettings["Username"];
    protected static string SECRET = System.Configuration.ConfigurationManager.AppSettings["Secret"];
    protected static string ReportSuiteID = System.Configuration.ConfigurationManager.AppSettings["ReportSuiteID"];
    private static string ENDPOINT = "https://api5.omniture.com/admin/1.4/rest/";
    protected static string environment = "dev"; 

    static void Main(string[] args)
    {
        DateTime previousDay = DateTime.Today.AddDays(-1);
        string json = RequestJsonBuilder(previousDay, previousDay, ReportSuiteID);
        string response = callMethod("Report.Queue", json, 15);

        var jss = new JavaScriptSerializer();
        var requestDetails = jss.Deserialize<Dictionary<string, string>>(response);
    }

    /*Build the json for the methods Report.GetStatus and Report.Get*/
    public static string RequestJsonBuilderStatus(string id)
    {
        ReportID json = new ReportID() { reportID = id };

        var serializer = new JavaScriptSerializer();
        var serializedResult = serializer.Serialize(json);
        return serializedResult;
    }

    /*Build the json for the method Report.Queue*/
    static string RequestJsonBuilder(DateTime StartDate, DateTime EndDate, string ReportSuiteID)
    {
        //Build the list of metrics to send with the request
        var listMetrics = new List<Metrics>();
        listMetrics.Add(new Metrics() { id = "visits" });


        //Build the list of elements to send with the request
        var listElements = new List<Elements>();
        listElements.Add(new Elements() { id = "page" , top = "25"});

        var serializer2 = new JavaScriptSerializer();
        Dictionary<string, RankedRequest> dic = new Dictionary<string, RankedRequest>();
        dic.Add("reportDescription", new RankedRequest()
        {
            reportSuiteID = ReportSuiteID,
            dateFrom = StartDate.ToString("yyyy-MM-dd"),
            dateTo = EndDate.ToString("yyyy-MM-dd"),
            metrics = listMetrics,
            elements = listElements,
            source = "warehouse"

        });
        var serializedResult2 = serializer2.Serialize(dic);
        return serializedResult2;
    }

    /*Build the rest call to the Adobe Analytics REST APII 1.4*/
    public static String callMethod(String method, String data, int secs)
    {
        Program prog = new Program();
        HttpWebResponse statusResponse = null;
        string responseXml = "";
        StringBuilder sbUrl = new StringBuilder(ENDPOINT + "?method=" + method);
        HttpWebRequest omniRequest = (HttpWebRequest)WebRequest.Create(sbUrl.ToString());
        string timecreated = generateTimestamp();
        string nonce = generateNonce();
        string digest = getBase64Digest(nonce + timecreated + SECRET);
        nonce = base64Encode(nonce);
        omniRequest.Headers.Add("X-WSSE: UsernameToken Username=\"" + USERNAME + "\", PasswordDigest=\"" + digest + "\", Nonce=\"" + nonce + "\", Created=\"" + timecreated + "\"");
        omniRequest.Method = "POST";
        omniRequest.ContentType = "text/json";

        //Write the json details to the request
        using (var streamWriter = new StreamWriter(omniRequest.GetRequestStream()))
        {
            string json = data;
            Console.WriteLine("\n 2.0 ############## Json request : \n\n " + json + "\n\n");
            streamWriter.Write(json);
        }

        //Get the response of the request
        try
        {
            Console.WriteLine("\n 2.0 ############## Sleeping thread for " + secs + "\n");

            using (HttpWebResponse statusResponse = (HttpWebResponse) omniRequest.GetResponse())
            {
                using (Stream receiveStream = statusResponse.GetResponseStream())
                {
                    using (StreamReader readStream = new StreamReader(receiveStream, Encoding.UTF8))
                    {
                        responseXml = readStream.ReadToEnd();
                        return responseXml;
                    }
                }
            }
        }
        catch (Exception ex) { throw ex; }
    }

    // other methods defined below
    // private static string getBase64Digest(string input)
    // private static string generateNonce()
    // public static string base64Encode(string data)
    // etc.
}

如何让HttpWebResponse等到实际收到HTTP 200响应。这可能需要几分钟到有时一小时,具体取决于我添加的指标和维度的数量。

我尝试过的事情还包括将第88行更改为以下内容:

How to process WebResponse when .NET throws WebException ((400) Bad Request)?

how to wait until a web request with HttpWebRequest is finished?

真诚地感谢所有人的帮助。

由于

1 个答案:

答案 0 :(得分:0)

您是否尝试设置超时?我最近在寻找类似的问题并找到了一个:

HttpWebRequest.GetResponse() keeps getting timed out