Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/284.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C#API GetResponse问题_C#_Httpwebrequest - Fatal编程技术网

C#API GetResponse问题

C#API GetResponse问题,c#,httpwebrequest,C#,Httpwebrequest,我是c#的新手,在尝试调用API以使用以下代码发布CSV数据时遇到了一个问题: HttpWebRequest request = (HttpWebRequest)WebRequest.Create("https://myurl"); request.Method = "POST"; request.Headers.Add("X-Api-Key:" + apiKey); request.Headers.Add("X-Api-Secret:" + ap

我是c#的新手,在尝试调用API以使用以下代码发布CSV数据时遇到了一个问题:

HttpWebRequest request = (HttpWebRequest)WebRequest.Create("https://myurl");
        request.Method = "POST";
        request.Headers.Add("X-Api-Key:" + apiKey);
        request.Headers.Add("X-Api-Secret:" + apiSecret);
        request.ContentType = "text/csv";

        using (StreamWriter swCSVData = new StreamWriter(request.GetRequestStream()))
        {
            StreamReader csvReader = new StreamReader(File.OpenRead("C:\\Test\\conf-ato-sprmbrinfo-batch-001.csv"));
            while (!csvReader.EndOfStream)
            {
                swCSVData.WriteLine(csvReader.ReadLine());
            }
            csvReader.Close();
        }
        HttpWebResponse response = null;

        try
        {
            Console.WriteLine("Attempting response....");
            response = (HttpWebResponse)request.GetResponse();
            Console.WriteLine("Got response....");

            using (Stream responseStream = response.GetResponseStream())
            {
             if (responseStream != null)
             {
                    using (StreamReader reader = new StreamReader(responseStream))
                    {
                        strResponseValue = reader.ReadToEnd();
                    }
                }
            }
            Console.WriteLine(strResponseValue);
            File.WriteAllText("C:\\Test\\apioutput.txt",strResponseValue);
        }
        catch ( Exception ex)
        {
            strResponseValue = "{\"errorMessages\":[\"" + ex.Message.ToString() + "\"],\"errors\":{}}";
        }
如果我在ptsv2.com上使用post测试运行这段代码,那么我可以看到api调用与我预期的一样,并得到响应。但是,当我将代码更改为指向所需的URL时,它似乎挂在以下行上:

response=(HttpWebResponse)request.GetResponse()

有人知道为什么会发生这种情况吗

也很高兴有任何建议,使我的代码更好


提前感谢。

一旦我看到异常被返回,就发现这是一个安全问题。我必须为我的请求添加以下代码行:

ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;

感谢那些花时间对我最初的问题发表评论的人。

它在那里能挂多久?CSV文件有多大?CSV文件只有一行,所以什么都没有。总共超过1k个字符。我想我至少留了5分钟左右,但我想我希望响应是相当即时的。尝试使用
using(HttpWebResponse=(HttpWebResponse)request.GetResponse(){//your code here}
而不仅仅是
response=(HttpWebResponse)request.GetResponse()
并从代码中删除这一行
HttpWebResponse=null这似乎没有帮助。到目前为止,进程已经运行了2分钟以上,但我将等待一段时间,看看它是否返回了一些内容。如果响应格式是JSON,我的代码会有问题吗?