找到c#方式发送http请求

时间:2011-07-20 18:20:00

标签: c# http automation httprequest httpresponse

我正在尝试开发一个Microsoft Excel插件,以将Excel工作表数据发送到Web应用程序。它将要求插件提示用户名和密码,然后将登录http请求发送到Web应用程序以获取会话。然后它会将数据上传到Web应用程序。我应该使用什么.net?

2 个答案:

答案 0 :(得分:5)

发布方法示例,用于发送用户名和密码。上传文件只需在google.com或bing.com上搜索“文件上传C#”或尝试C#'s WebClient.UploadFile, Code Project

// Create a request using a URL that can receive a post. 
WebRequest request = WebRequest.Create("http://example.com");
// Set the Method property of the request to POST.
request.Method = "POST";
// Create POST data and convert it to a byte array.
string postData = "username=user&passsword=pass";
byte[] byteArray = Encoding.UTF8.GetBytes (postData);
// Set the ContentType property of the WebRequest.
request.ContentType = "application/x-www-form-urlencoded";
// Set the ContentLength property of the WebRequest.
request.ContentLength = byteArray.Length;
// Get the request stream.
Stream dataStream = request.GetRequestStream ();
// Write the data to the request stream.
dataStream.Write (byteArray, 0, byteArray.Length);
// Close the Stream object.
dataStream.Close ();
// Get the response.
WebResponse response = request.GetResponse ();
// Display the status.
Console.WriteLine (((HttpWebResponse)response).StatusDescription);
// Get the stream containing content returned by the server.
dataStream = response.GetResponseStream ();
// Open the stream using a StreamReader for easy access.
StreamReader reader = new StreamReader (dataStream);
// Read the content.
string responseFromServer = reader.ReadToEnd ();
// Display the content.
Console.WriteLine (responseFromServer);
// Clean up the streams.
reader.Close ();
dataStream.Close ();
response.Close();                                                                                         

答案 1 :(得分:2)

对于.NET中的HTTP通信,请尝试System.Net.WebClientSystem.Net.HttpWebRequest