HttpWebRequest 保存Cookies,模拟Session登录

 前面使用HttpWebRequest 对象可以抓取网页中一些资料,不过有些页面可以直接打开,而有些页面必登录之后才能打开,也就是在登录后保存登录信息在Session,这样就可以访问有权限的页面了。下面通过HttpWebRequest获取网页内容并保持session,最主要的就是存储cookie。第二次请求网页的时候把cookie传送过去,这样就可以访问有Session的页了。

 

       CookieContainer cookies = new CookieContainer();
        private void button1_Click(object sender, EventArgs e)
        {
            var str = "username=wzh&userpwd=1223";//登录名和密码
            var buf = Encoding.UTF8.GetBytes(str);

            var loginUrl="http://localhost:15993/home/login";//提交登录地址
            var postUrl="http://localhost:15993/home/Item";//此页需登录后才能访问

            HttpWebRequest res = (HttpWebRequest)HttpWebRequest.Create(new Uri(loginUrl));
            res.Method = "post";
            res.CookieContainer = cookies;

            //向提交流中写入信息
            var writeStream = res.GetRequestStream();
            writeStream.Write(buf, 0, buf.Length);
            writeStream.Close();
            writeStream.Dispose();

            res.GetResponse().Close();//此句完成登录,无此句无法得到cookie

            res = (HttpWebRequest)HttpWebRequest.Create(new Uri(postUrl));//具体session才能访问的页
            res.CookieContainer = cookies;//设置cookies
            var resStream = new StreamReader(res.GetResponse().GetResponseStream());//取到返回值
            textBox1.Text = resStream.ReadToEnd();//显示返回值
            resStream.Close();
            resStream.Dispose();
            res.Abort();
        }

 

posted @ 2017-05-11 19:26  lunawzh  阅读(5256)  评论(0编辑  收藏  举报