C#winform请求http的实现(get,post)

C#winform请求http的实现(get,post)

目录

一:.Net中有两个类 HttpWebRequest 和HttpWebResponse 类来实现Http的请求

二: HTTP定义了与服务器交互的不同方法

POST与GET的差异

两个简单的Get请求和Post请求

1.Get请求

2.Post请求

一个小测试

一:.Net中有两个类 HttpWebRequest 和HttpWebResponse 类来实现Http的请求

实现步骤:

1.通过WebRequest类创建一个HttpWebRequest的对象,该对象可以包含Http请求信息。
2.设置HttpWebRequest对象,其实就是设置Http请求报文的信息内容。
3.从HttpWebRequest对象中获取HttpWebResponse对象,该对象包含Http响应信息。
4.从响应信息中获取响应头信息和响应主体信息。

二: HTTP定义了与服务器交互的不同方法

基本方法有GET,POST,PUT,DELETE,分别对于查,该,增,删。一般情况下我们只用到GET和POST,

POST与GET的差异

1.GET是从服务器上获取数据,POST是向服务器传送数据。
2.GET是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。POST是通过HTTPPOST机制,将表单内各个字段与其内容放置在HTML HEADER内一起传送到ACTION属性所指的URL地址。用户看不到这个过程。
3.对于GET方式,服务器端用Request.QueryString获取变量的值,对于POST方式,服务器端用Request.Form获取提交的数据。
4.GET传送的数据量较小,不能大于2KB(这主要是因为受URL长度限制)。POST传送的数据量较大,一般被默认为不受限制。但理论上,限制取决于服务器的处理能力。
5.GET安全性较低,POST安全性较高。因为GET在传输过程,数据被放在请求的URL中,而如今现有的很多服务器、代理服务器或者用户代理都会将请求URL记录到日志文件中,然后放在某个地方,这样就可能会有一些隐私的信息被第三方看到。另外,用户也可以在浏览器上直接看到提交的数据,一些系统内部消息将会一同显示在用户面前。POST的所有操作对用户来说都是不可见的。

两个简单的Get请求和Post请求 1.Get请求 string strURL = "http://localhost/WinformSubmit.php?tel=11111&name=张三"; System.Net.HttpWebRequest request; // 创建一个HTTP请求 request = (System.Net.HttpWebRequest)WebRequest.Create(strURL); //request.Method="get"; System.Net.HttpWebResponse response; response = (System.Net.HttpWebResponse)request.GetResponse(); System.IO.StreamReader myreader = new System.IO.StreamReader(response.GetResponseStream(), Encoding.UTF8); string responseText = myreader.ReadToEnd(); myreader.Close(); MessageBox.Show(responseText); 2.Post请求 string strURL = "http://localhost/WinformSubmit.php"; System.Net.HttpWebRequest request; request = (System.Net.HttpWebRequest)WebRequest.Create(strURL); //Post请求方式 request.Method = "POST"; // 内容类型 request.ContentType = "application/x-www-form-urlencoded"; // 参数经过URL编码 string paraUrlCoded = System.Web.HttpUtility.UrlEncode("keyword"); paraUrlCoded += "=" + System.Web.HttpUtility.UrlEncode("多月"); byte[] payload; //将URL编码后的字符串转化为字节 payload = System.Text.Encoding.UTF8.GetBytes(paraUrlCoded); //设置请求的 ContentLength request.ContentLength = payload.Length; //获得请 求流 System.IO.Stream writer = request.GetRequestStream(); //将请求参数写入流 writer.Write(payload, 0, payload.Length); // 关闭请求流 writer.Close(); System.Net.HttpWebResponse response; // 获得响应流 response = (System.Net.HttpWebResponse)request.GetResponse(); System.IO.StreamReader myreader = new System.IO.StreamReader(response.GetResponseStream(), Encoding.UTF8); string responseText = myreader.ReadToEnd(); myreader.Close(); MessageBox.Show(responseText); 一个小测试

请求百度首页( http://www.baidu.com )的内容,也就是要获得百度首页的html内容。

创建HttpWebRequest请求,设置请求报文信息

//请求 string uri = http://www.baidu.com; HttpWebRequest request = HttpWebRequest.Create(uri) as HttpWebRequest; request.Method = "GET"; //请求方法 request.ProtocolVersion = new Version(1, 1); //Http/1.1版本 //Add Other ...

接收响应,输出响应头部信息以及主体信息

HttpWebResponse response=request.GetResponse() as HttpWebResponse; //Header foreach (var item in response.Headers) { this.txt_Header.Text += item.ToString()+": " + response.GetResponseHeader (item.ToString()) + System.Environment.NewLine; } //如果主体信息不为空,则接收主体信息内容 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;

到此这篇关于C# winform 请求http的实现(get,post)的文章就介绍到这了,更多相关C# winform 请求http内容请搜索易知道(ezd.cc)以前的文章或继续浏览下面的相关文章希望大家以后多多支持易知道(ezd.cc)!

推荐阅读

    优化PostgreSQL中的批量更新性能

    优化PostgreSQL中的批量更新性能,数据,表格,在Ubuntu 12.04上使用PG 9.1. 我们目前需要24小时才能运行大量UPDATE数据库上的语句,其形式

    MacChrome打开HTTPS证书错误解决方案

    MacChrome打开HTTPS证书错误解决方案,,评论:在Chrome浏览器下,总是建议站点的安全证书不可信。有一个很好的解决方案,你可以试试看。 GoAge

    postgresql的ALTER常用操作

    postgresql的ALTER常用操作,字段,数据类型,postgresql版本:psql (9.3.4)1、增加一列ALTER TABLE table_name ADD column_name datatype;

    PostgreSQL数据库修改sql表的方法汇总

    PostgreSQL数据库修改sql表的方法汇总,字段,默认值, 一,修改表 PostgreSQL 提供了一族命令用于修改现有表。 可以实现: 增加字段, 删除字段,

    ln的公式是什么?target.lnk是什么

    ln的公式是什么?target.lnk是什么,对数,文件夹,ln的公式是什么ln的公式:ln(mn)=lnm+lnn;ln(m/n)=lnm-lnn;ln(m^n)=nlnm;ln1=0;lne=1。推导公式:(1)lo

    get+laid+off是什么意思

    get+laid+off是什么意思,短语,英语,本文目录get+laid+off是什么意思lay off裁员,解雇,那被解雇是be laid off吗高中英语短语:掉下 处于麻烦当

    为PostgreSQL添加插件

    为PostgreSQL添加插件,文件,插件, 我目前了解的PG插件大约有两种,一种是利用hook,另一种是建立C函数,然后在数据库中进行关联。PG本身就