Loading

C#模拟登录后请求查询

需求是这样子的,想开发一个外挂程序,能够抓取别的系统的数据,从而实现数据验证。

比如这样一个界面:

使用Chrome浏览器分析http请求和响应过程以及页面的html代码,发现这是一个ajax请求,于是跟踪找到了具体的请求地址和查询时提交的数据。

于是就可以请求这个地址,并且封装提交的数据进行http请求即可。

但实验后发现,需要先登录系统然后才能进行查询请求。

分析系统登录部分代码发现,仍然是一个ajax post请求后台的代码,截图如下:

从js代码可以看出res=899为登录失败,其它为登录成功。

于是思路就确定了,先模拟登陆系统,然后使用相同的cookie,再次请求查询即可获得数据。

 

登录方法:

public static string PostLogin(string postData, string requestUrlString, ref CookieContainer cookie)
{
    UTF8Encoding encoding = new UTF8Encoding();
    byte[] data = encoding.GetBytes(postData);
    //向服务端请求
    HttpWebRequest myRequest = (HttpWebRequest)WebRequest.Create(requestUrlString);
    myRequest.UserAgent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.96 Safari/537.36";
    myRequest.Method = "POST";
    myRequest.ContentType = "application/x-www-form-urlencoded";
    myRequest.ContentLength = data.Length;
    myRequest.CookieContainer = new CookieContainer();
    myRequest.AllowAutoRedirect = true;

    Stream newStream = myRequest.GetRequestStream();
    newStream.Write(data, 0, data.Length);
    newStream.Close();
    //将请求的结果发送给客户端(界面、应用)
    HttpWebResponse myResponse = (HttpWebResponse)myRequest.GetResponse();
    cookie.Add(myResponse.Cookies);
    StreamReader reader = new StreamReader(myResponse.GetResponseStream(), Encoding.UTF8);
    return reader.ReadToEnd();
}

登录进系统后查询方法:

public static string PostRequest(string postData, string requestUrlString, CookieContainer cookie)
{
    UTF8Encoding encoding = new UTF8Encoding();
    byte[] data = encoding.GetBytes(postData);
    HttpWebRequest myRequest = (HttpWebRequest)WebRequest.Create(requestUrlString);
    myRequest.UserAgent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.96 Safari/537.36";
    myRequest.Method = "POST";
    myRequest.ContentType = "application/x-www-form-urlencoded";
    myRequest.ContentLength = data.Length;
    myRequest.CookieContainer = cookie;
    myRequest.AllowAutoRedirect = true;

    Stream newStream = myRequest.GetRequestStream();
    newStream.Write(data, 0, data.Length);
    newStream.Close();
    HttpWebResponse myResponse = (HttpWebResponse)myRequest.GetResponse();
    StreamReader reader = new StreamReader(myResponse.GetResponseStream(), Encoding.UTF8);
    return reader.ReadToEnd();
}

调用部分代码:

CookieContainer cc = new CookieContainer();
string url_login = "http://10.77.197.23:7001/yzjy/login.action?method=login1";
string postData_login = "submitData={\"username\":\"登录账号\",\"userpwd\":\"密码\"}";
string result_login = PostLogin(postData_login, url_login, ref cc);
if (result_login.Equals("1748"))//1748表示登录成功
{
    string url_getRyData = "http://10.77.197.23:7001/yzjy/Rygl.do?method=getRyData";
    string postData_RyData = "aac002=" + sfz + "&aac003=" + xm + "&pageIndex=0&pageSize=30";
    string result_RyData = PostRequest(postData_RyData, url_getRyData, cc);
    RyData ry = JsonConvert.DeserializeObject<RyData>(result_RyData);
    if (ry.total <= 0)
    {
        MessageBox.Show("对不起,没有查找到当前人信息。", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
        return;
    }
}

返回json数据,封装类的代码:

public class RyData
{
    public int total { get; set; }
    public Data[] data { get; set; }
}

public class Data
{
    public string aac161_name { get; set; }
    public string tbr { get; set; }
    public string aac161 { get; set; }
    public string aae100 { get; set; }
    public string czdz { get; set; }
    public string aac001 { get; set; }
    public string aac002 { get; set; }
    public string aae005 { get; set; }
    public string aac003 { get; set; }
    public string aac004 { get; set; }
    public string aac005 { get; set; }
    public string aac006 { get; set; }
    public string aac009_name { get; set; }
    public string aac009 { get; set; }
    public string aac005_name { get; set; }
    public string hjdz { get; set; }
    public string aac011_name { get; set; }
    public string aae011_name { get; set; }
    public string aae036 { get; set; }
    public string aac058 { get; set; }
    public string aac016 { get; set; }
    public string aac016_name { get; set; }
    public string aac004_name { get; set; }
    public string aac058_name { get; set; }
    public string aac024_name { get; set; }
    public string rn { get; set; }
}

 

参考资料:

http://www.cnblogs.com/ok519/p/3488091.html

posted @ 2017-05-10 12:19  guwei4037  阅读(7177)  评论(0编辑  收藏  举报