本文實例講述了C#實現簡單的Http請求的方法。分享給大家供大家參考。具體分析如下:
通過.Net中的兩個類HttpWebRequest類,HttpWebResponse類來實現Http的請求,響應處理。
第一個小測試是請求百度首頁(http://www.baidu.com)的內容,也就是要獲得百度首頁的html內容,
實現步驟:
1.通過WebRequest類創建一個HttpWebRequest的對象,該對象可以包含Http請求信息。
(這里有點供大家思考:為什么要通過父類WebRequest來創建這個對象,而不能new一個HttpWebRequest來創建,在HttpWebRequest類中的構造函數是:protected HttpWebRequest(SerializationInfo serializationInfo, StreamingContext streamingContext); )
2.設置HttpWebRequest對象,其實就是設置Http請求報文的信息內容。
3.從HttpWebRequest對象中獲取HttpWebResponse對象,該對象包含Http響應信息。
4.從響應信息中獲取響應頭信息和響應主體信息。
部分實現代碼如下:
創建HttpWebRequest請求,設置請求報文信息
接收響應,輸出響應頭部信息以及主體信息
//如果主體信息不為空,則接收主體信息內容
if (response.ContentLength <= 0)
return;
//接收響應主體信息
using(Stream stream =response.GetResponseStream())
{
int totalLength=(int)response.ContentLength;
int numBytesRead=0;
byte[] bytes=new byte[totalLength+1024];
//通過一個循環讀取流中的數據,讀取完畢,跳出循環
while( numBytesRead < totalLength )
{
int num=stream.Read(bytes,numBytesRead,1024); //每次希望讀取1024字節
if( num==0 ) //說明流中數據讀取完畢
break;
numBytesRead+=num;
}
}
//將接收到的主體數據顯示到界面
string content=Encoding.UTF8.GetString(bytes);
this.txt_Content.Text=content;
第二個小測試是請求網上的一張圖片,并將圖片保存到本地。
實現步驟與第一個小測試的非常類似,通過圖片的url向服務器進行請求,然后接收響應,響應的主體信息內容保存為本地圖片文件。一小點不同之處就在于需要將主體內容保存為文件形式,不是顯示到界面上。
關鍵代碼如下:
附:運行結果如下圖:
希望本文所述對大家的C#程序設計有所幫助。
新聞熱點
疑難解答