浏览器浏览Web页面的时候也无非是 post 或者 get ,带 cookies 或者不带 cookies 这几种方式。
有了下面这几个方法,什么web页面上的自动投票啊,自动查数据啊等等,全部搞定!
有个工具可以让你查看到IE浏览页面时候的通信内容:httplook , 也顺便推荐一下。
using System.Web;
/// <summary>
/// Post方式请求页面
/// </summary>
/// <param name="url">地址</param>
/// <param name="postData">post数据</param>
/// <returns>响应</returns>
private HttpWebResponse RequestbyPost(string url, string postData)
{
Uri lcUri = new Uri(url);
HttpWebRequest loHttp = (HttpWebRequest)WebRequest.Create(lcUri);
//string lcPostData = HttpUtility.UrlEncode(postData, System.Text.Encoding.Default);
string lcPostData = postData;
loHttp.Method = "POST";
loHttp.ContentType = "application/x-www-form-urlencoded";
loHttp.KeepAlive = true;
byte[] lbPostBuffer = System.Text.Encoding.Default
.GetBytes(lcPostData);
loHttp.ContentLength = lbPostBuffer.Length;
Stream loPostData = loHttp.GetRequestStream();
loPostData.Write(lbPostBuffer, 0, lbPostBuffer.Length);
loPostData.Close();
return (HttpWebResponse)loHttp.GetResponse();
}
/// <summary>
/// Post方式请求页面
/// </summary>
/// <param name="url">地址</param>
/// <param name="postData">post数据</param>
/// <returns>响应</returns>
private HttpWebResponse RequestbyPost(string url, string postData, string cookieHeader)
{
Uri lcUri = new Uri(url);
HttpWebRequest loHttp = (HttpWebRequest)WebRequest.Create(lcUri);
//string lcPostData = HttpUtility.UrlEncode(postData, System.Text.Encoding.Default);
string lcPostData = postData;
loHttp.Method = "POST";
loHttp.ContentType = "application/x-www-form-urlencoded";
CookieContainer cookie1 = new CookieContainer();
loHttp.CookieContainer = cookie1;
loHttp.CookieContainer.SetCookies(lcUri, cookieHeader);
loHttp.KeepAlive = true;
byte[] lbPostBuffer = System.Text.Encoding.Default
.GetBytes(lcPostData);
loHttp.ContentLength = lbPostBuffer.Length;
Stream loPostData = loHttp.GetRequestStream();
loPostData.Write(lbPostBuffer, 0, lbPostBuffer.Length);
loPostData.Close();
return (HttpWebResponse)loHttp.GetResponse();
}
/// <summary>
/// Get方式请求页面
/// </summary>
/// <param name="url">地址</param>
/// <returns>响应</returns>
private HttpWebResponse RequestbyGet(string url)
{
Uri lcUri = new Uri(url);
HttpWebRequest loHttp = (HttpWebRequest)WebRequest.Create(lcUri);
loHttp.Method = "GET";
//loHttp.ContentType = "application/x-www-form-urlencoded";
return (HttpWebResponse)loHttp.GetResponse();
}
/// <summary>
/// Get方式请求页面
/// </summary>
/// <param name="url">地址</param>
/// <param name="cookieHeader">cookieHeader</param>
/// <returns>响应</returns>
private HttpWebResponse RequestbyGet(string url, out string cookieHeader)
{
Uri lcUri = new Uri(url);
HttpWebRequest loHttp = (HttpWebRequest)WebRequest.Create(lcUri);
loHttp.Method = "GET";
//loHttp.ContentType = "application/x-www-form-urlencoded";
loHttp.AllowAutoRedirect = true;
loHttp.CookieContainer = new CookieContainer();
loHttp.KeepAlive = true;
HttpWebResponse httpWebResponse = (HttpWebResponse)loHttp.GetResponse();
cookieHeader = loHttp.CookieContainer.GetCookieHeader(lcUri);
return httpWebResponse;
}
分享到:
相关推荐
GET用于获取资源,而POST则用于提交数据,创建新资源。 3. **POST方法**:POST请求常用于向服务器提交数据,例如在表单提交时,数据会被封装在请求体中发送到服务器。在Node.js中,我们可以使用内置的`http`模块或...
GET主要用于获取资源,它将参数附加到URL后面,对数据的长度有限制,并且通常会被浏览器记录在历史记录和缓存中,因此不适合传输敏感信息。而POST方法则用于向服务器发送数据,通常用于表单提交,可以处理大量数据,...
- **GET**:适用于数据查询操作,如搜索功能、获取页面等。GET请求可以被缓存、收藏为书签、记录在浏览器历史中,方便用户重复访问。 - **POST**:适用于对数据库进行增删改操作,如提交表单、更新记录等。这些操作...
### jsp中post和get传输方式的区别 在Web开发领域,特别是使用Java Server Pages (JSP) 进行网页开发时,GET与POST是两种最常见的HTTP请求方法。这两种方法各有其适用场景及特点,理解它们之间的区别对于提高网站的...
在 Java Web 中,GET 和 POST 方法都是服务器的请求方式,但是它们传输表单的方式不同。GET 方法是通过 URL 传递参数的,而 POST 方法是通过 Request 体来传输数据的。POST 方法的优点是可以传输大量数据,但是缺点...
在HTML表单中,`method`属性用于定义数据提交的方式,主要有两种选择:`GET`和``POST`。这两种方法在数据传输过程中与HTTP协议的GET和POST方法紧密相关,各自具有不同的特点和用途。 1. GET方法: - GET主要用于从...
总的来说,理解GET和POST方法对于任何Web开发者来说都是至关重要的,它们是构建交互式Web应用程序的基础。通过掌握这两种方法,你可以更好地设计和实现登录和其他数据提交功能,确保用户数据的安全性和交互的效率。
例如,获取静态页面内容通常用GET,而提交表单、上传文件等操作则更适合用POST。在开发Web应用时,理解这两种请求方式的区别至关重要,因为它们直接影响到应用程序的性能、安全性和用户体验。 通过阅读...
本文将深入探讨`jQuery`中的`POST`和`GET`异步调用方式。 1. **GET方式** `GET`是最常见的HTTP请求方法,通常用于获取资源。在jQuery中,我们可以使用`$.get()`函数发起GET请求。它的基本语法如下: ```...
另外,对于现代Web应用,如果使用了AJAX(XMLHttpRequest或Fetch API),可以考虑使用`fetch` API的`POST`请求配合`window.location.replace`或`window.location.assign`来模拟打开新页面,但这种方法实际上并没有...
总结来说,jQuery的`get()`和`post()`方法是进行Ajax交互的重要手段,它们使得JavaScript能够轻松地与服务器进行数据通信,从而实现页面的动态更新,提高了用户体验。理解和熟练运用这两个方法,对于提升Web开发技能...
* * PHP与Web页面交互 -----PHP 获取表单信息1 课程内容 获取文本框的值 获取文件域的值 获取复选框的值 PHP获取表单信息 在Web开发过程中,表单提交是数据传输过程中很重要的一部分,作为以PHP为后台开发语言的...
在Web开发中,GET与POST是最常见的两种HTTP请求方式,它们在功能、安全性、数据传输等方面存在显著差异。本文将基于提供的文件内容对这两种方法进行详细解析。 #### 1. 基本概念 - **GET**:用于从服务器获取数据...
GET请求通过`Request.QueryString`获取参数,而POST请求通过`Request.InputStream`读取请求体。 为了使这个处理程序可访问,需要在web.config文件中注册它。在`<system.web>`部分添加以下代码: ```xml <system....
在Web开发中,GET和POST是HTTP协议中最常见的两种请求方法,它们用于客户端(通常是浏览器)向服务器发送数据。理解这两种方法的区别和应用场景是每个Web开发者的基础知识。 **GET方法**: 1. GET方法用于从服务器...
在Web开发中,数据传输是不可或缺的一环,而POST和GET是HTTP协议中最常见的两种请求方法。当我们在处理用户输入或者交互时,可能会遇到乱码问题,这主要涉及到字符编码的处理。本文将深入探讨如何处理POST和GET提交...
GET请求通常用于获取静态页面、图片、CSS样式表等资源。GET请求的参数通过URL传递,限制在2KB左右,并且因为参数可见,所以不适合传递敏感信息。例如,`http://example.com/search?q=keyword` 就是一个GET请求,其中...
1. **GET方式**:在URL中附加参数,数据可见且有限制(一般不超过2KB),适合获取少量数据。 2. **POST方式**:数据放在请求体中,对数据量无限制,适合传递大量或敏感数据。 在调用WCF服务时,我们需要创建一个WCF...
GET请求通常用于获取服务器上的资源,如HTML页面、图片等。HttpGet允许我们设置URL和请求头,但不支持请求体。 4. 所需jar包:使用HttpClient、HttpPost和HttpGet需要引入以下核心jar包: - `httpclient.jar`:...