C#使用HttpWebRequest与HttpWebResponse模拟用户登录

模拟艺龙旅游网登录,供大家参考,具体内容如下

想模拟登录,首先整理一下流程

1.通过360浏览器(IE,火狐等等)F12开发人员工具抓到相关数据

2.获取验证码(拿到cookie),登录时也需要使用

3.登录

F12调出开发人员工具,输入用户名,密码登录,看我们抓到了什么信息。

Request URL:这个就是登录请求的url 
https://secure.elong.com/passport/ajax/elongLogin

方式POST
Form Data:这个是我们要POST传输的数据:

userName=xzdylyh&passwd=12313&validateCode=验证码&rememberMe=false

其它一些重要信息在Request Headers中

*****************************************************************

我使用C# 设计的winform界面

复制代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Web;
using System.Net;
using System.IO;
using System.Data;
namespace HTTPHELPER
{
  public class ELOGN_LOGIN
  {

    public static CookieContainer container = null; //存储验证码cookie

    #region 登录
    public string requestM(string uName,string passwd,string vaildate)
    {
      HttpWebRequest request = null;
      HttpWebResponse response = null;
      try
      {
        request = (HttpWebRequest)HttpWebRequest.Create("https://secure.elong.com/passport/ajax/elongLogin");
        request.Method = "Post";
        request.ContentType = "application/x-www-form-urlencoded; charset=UTF-8";
        request.UserAgent = "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.101 Safari/537.36";
        request.AllowAutoRedirect = true;
        request.CookieContainer = container;//获取验证码时候获取到的cookie会附加在这个容器里面
        request.KeepAlive = true;//建立持久性连接
        //整数据
        string postData = string.Format("userName={0}&passwd={1}&validateCode={2}&rememberMe=true", uName, passwd, vaildate);
        ASCIIEncoding encoding = new ASCIIEncoding();
        byte[] bytepostData = encoding.GetBytes(postData);
        request.ContentLength = bytepostData.Length;

        //发送数据 using结束代码段释放
        using (Stream requestStm = request.GetRequestStream())
        {
          requestStm.Write(bytepostData, 0, bytepostData.Length);
        }

        //响应
        response = (HttpWebResponse)request.GetResponse();
        string text = string.Empty;
        using (Stream responseStm = response.GetResponseStream())
        {
          StreamReader redStm = new StreamReader(responseStm, Encoding.UTF8);
          text = redStm.ReadToEnd();
        }

        return text;
      }
      catch (Exception ex)
      {
        var msg = ex.Message;
        return msg;
      }

    }
    #endregion

    #region 获取验证码
    public Stream getCodeStream(string codeUrl)
    {

      //验证码请求
      HttpWebRequest request = (HttpWebRequest)WebRequest.Create(codeUrl);
      request.Method = "GET";
      request.ContentType = "application/x-www-form-urlencoded";
      request.UserAgent = "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:5.0.1) Gecko/20100101 Firefox/5.0.1";
      request.Accept = "image/webp,*/*;q=0.8";
      request.CookieContainer = new CookieContainer();//!Very Important.!!!
      container = request.CookieContainer;
      var c = request.CookieContainer.GetCookies(request.RequestUri);
      HttpWebResponse response = (HttpWebResponse)request.GetResponse();
      response.Cookies = container.GetCookies(request.RequestUri);

     Stream stream = response.GetResponseStream();
     return stream;
    }
  }
    #endregion
}
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.IO;
using HTTPHELPER;
namespace WindowsFormsApplication8
{
  public partial class ELONG_LOGIN_FORM : Form
  {
    public ELONG_LOGIN_FORM()
    {
      InitializeComponent();
    }

    private void button1_Click(object sender, EventArgs e)
    {

      ELOGN_LOGIN elongLogin = new ELOGN_LOGIN();

      var rmsg = elongLogin.requestM(txtuserName.Text,txtPassword.Text,txtVaildata.Text);
      MessageBox.Show(rmsg);
    }

    private void ELONG_LOGIN_FORM_Load(object sender, EventArgs e)
    {
      ReflshPicImage();//更新验证码
    }

    //更新验证码
    public void ReflshPicImage()
    {
      string codeUrl = "https://secure.elong.com/passport/getValidateCode";
      ELOGN_LOGIN agent = new ELOGN_LOGIN();
      Stream stmImage = agent.getCodeStream(codeUrl);
      picValidate.Image = Image.FromStream(stmImage);
    }

    private void btnReValidate_Click(object sender, EventArgs e)
    {
      ReflshPicImage();//更新验证码
    }

    private void picValidate_Click(object sender, EventArgs e)
    {
      ReflshPicImage();//更新验证码
    }
  }
}

最后执行效果,登录的session已经成功返回。

(0)

相关推荐

  • C#实现的三种模拟自动登录和提交POST信息的方法

    本文实例讲述了C#实现的三种模拟自动登录和提交POST信息的方法.分享给大家供大家参考,具体如下: 网页自动登录(提交Post内容)的用途很多,如验证身份.程序升级.网络投票等,以下是用C#实现的方法. 网页自动登录和提交POST信息的核心就是分析网页的源代码(HTML),在C#中,可以用来提取网页HTML的组件比较多,常用的用WebBrowser.WebClient.HttpWebRequest这三个.以下就分别用这三种方法来实现: 1.WebBrowser是个"迷你"浏览器,其特点

  • C#实现简单的登录界面

    首先我们来看一个简单的制作过程 打开visual 2010,新建窗体,既然是登录窗口,那么就不让它出现最大化.最小化以及拖拉大小功能(上一节已经提到过怎么设置大小),如图所示,甚至窗体的Text属性值为"登录窗口",大小随意. 创建窗体之后就开始界面详细的组件布局了,主要是在左边拖拉控件,然后放到窗体中去,定义属性值.这些都比较简单. 到了代码响应阶段,双击登录按钮,进入代码视图: private void button1_Click(object sender, EventArgs

  • C#实现登录窗口(不用隐藏)

    (1).在程序入口处,打开登录窗口 复制代码 代码如下: static void Main() { Application.EnableVisualStyles(); Application.SetCompatibleTextRenderingDefault(false); Form form = new login(); form.Show(); Application.Run(); }   复制代码 代码如下: private void button1_Click(object sender

  • C#可用于登录验证码的四位随机数生成方法

    本文实例讲述了C#可用于登录验证码的四位随机数生成方法.分享给大家供大家参考.具体实现方法如下: 这里提供了两种方法,调用其一即可: 复制代码 代码如下: using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace SJ_random {     class Class_main     {        

  • C#.NET实现网页自动登录的方法

    本文实例讲述了C#.NET实现网页自动登录的方法.分享给大家供大家参考.具体如下: 用C#语言编写一个Windows Form应用程序,实现自动登录一个特定的页面. 下面以自动登录:http://localhost/Web/Login.aspx 作为例子,讲解如何模拟手工输入用户名密码并点击登录,实现自动登录. 新建一个C#应用程序,给应用程序起个名字,如AutoLogin,在窗体中添加一个TextBox.Button,及WebBrowser控件,并为WebBrowser控件添加webBrows

  • C#有效防止同一账号多次登录(附三种方法)

    本文先为大家介绍如何利用缓存Cache方便地实现此功能. Cache与Session这二个状态对像的其中有一个不同之处,Cache是一个全局对象,作用的范围是整个应用程序,所有用户: 而Session是一个用户会话对象,是局部对象,用于保存单个用户的信息. 只要把每次用户登录后的用户信息存储在Cache中,把Cache的Key名设为用户的登录名,Cache的过期时间设置为Session的超时时间,在用户每次登录的时候去判断一下Cache[用户名]是否有值,如果没有值,证明该用户没有登录,否则该用

  • asp.net c#采集需要登录页面的实现原理及代码

    首先说明:代码片段是从网络获取,然后自己修改.我想好的东西应该拿来分享. 实现原理:当我们采集页面的时候,如果被采集的网站需要登录才能采集.不管是基于Cookie还是基于Session,我们都会首先发送一个Http请求头,这个Http请求头里面就包含了网站需要的Cookie信息.当网站接收到发送过来的Http请求头时,会从Http请求头获取相关的Cookie或者Session信息,然后由程序来处理,决定你是否有权限访问当前页面. 好了,原理搞清楚了,就好办了.我们所要做的仅仅是在采集的时候(或者

  • c#调用存储过程实现登录界面详解

    1,创建存储过程 复制代码 代码如下: create proc Pro_Login(@UserName nvarchar(10),@PassWord nvarchar(10))as select * from [User] UserName=@UserName and PassWord=@PassWord 2,通过类是实现配置数据库字符串连接 复制代码 代码如下: class ConnectionString{public static string conStr = "Data Source=

  • div弹出层的ajax登录(Jquery版+c#)

    页面初始化,界面如图所示: Server name文本框获取焦点时候,界面如图所示(这里可以改成你登录的验证码): 可以加载SQL Server服务列表,也是我的简易SQL查询分析器评论中静夜妙思给予的方法,非常感谢! 加载列表如下图所示: 可以随意地点击添加到Server name中,登录时截图所示: 文本框验证都写好了!还有Authentication验证方式,windows验证下面Login,Password文本框禁掉!由于时间原因,不上图了 demo.html(全部前台代码,js/css

  • C# Winform中实现主窗口打开登录窗口关闭的方法

    在使用C#进行Winform编程时,我们经常需要使用一个登录框来进行登录,一旦输入的用户名密码登录成功,这时登录窗口应该关闭,而且同时打开主程序窗口.该如何来实现呢? 乍一想,很简单啊,打开主窗口就用主窗口的Show()方法,而关闭登录窗口就用登录窗口的Close()方法即可.即代码如下: Program.cs中代码: 复制代码 代码如下: Application.Run(new FormLogin()); 登录窗口(FormLogin)代码: 复制代码 代码如下: private void b

随机推荐