• 从网页抓取数据的一般方法


    首先要了解对方网页的执行机制 ,这能够用httpwacth或者httplook来看一下http发送和接收的数据。这两个工具应该说是比較简单易懂的。这里就不再介绍了。主要关注的内容是header和post的内容。通常会包括cookie,Referer页面和其它一些乱其八糟可能看不懂的变量,还有就是正常交互的參数,比方须要post或者get的querystring所包括的东西。

    httplook和httpwacth 网上有非常多下载的,这里推荐使用httpwach,由于能够直接嵌入到ie中,个人认为这个比較好用。这两个工具能够到我上传在csdn的资源中下载,地址为

    http://download.csdn.net/user/jinjazz

    这里简单给出一段能够抓取数据的c#代码,比方登录某个站点,获取登录成功后的html代码,供数据分析使用。

    private   void  login()
            
    {
                System.Net.WebClient wb 
    =   new  System.Net.WebClient();

                System.Collections.Specialized.NameValueCollection header 
    =   new  System.Collections.Specialized.NameValueCollection();
                header.Add(
    " Cookie " " czJ_cookietime=2592000; czJ_onlineusernum=1651; czJ_sid=w4bGJd " );
                header.Add(
    " Referer " @" http://www.test_by_jinjazz.com.cn/bbs/login.php " );
                wb.Headers.Add(header);
                System.Collections.Specialized.NameValueCollection data 
    =   new  System.Collections.Specialized.NameValueCollection();
                data.Add(
    " formhash " " ebd2faac " );
                data.Add(
    " referer " " http://www.test_by_jinjazz.com.cn/bbs/search.php " );
                data.Add(
    " loginfield " " username " );
                data.Add(
    " username " " jinjazz " );
                data.Add(
    " password " " 999 " );
                data.Add(
    " questionid " " 0 " );
                data.Add(
    " answer " "" );
                data.Add(
    " cookietime " " 2592000 " );
                data.Add(
    " loginmode " "" );
                data.Add(
    " styleid " "" );
                data.Add(
    " loginsubmit " " 提交 " );

                
    byte [] b  =  wb.UploadValues( " http://www.test_by_jinjazz.com.cn/bbs/login.php " " Post " , data);
                
    string  strData  =  System.Text.Encoding.Default.GetString(b);
                Console.WriteLine(strData);
            }

    以上代码除了三个url之外其它数据都是真实的,当中header和data中的參数和值都是用httpwatch来监測后得到。

  • 相关阅读:
    兄弟连新版ThinkPHP视频教程2.ThinkPHP 3.1.2 MVC模式和URL访问
    兄弟连新版ThinkPHP视频教程1.ThinkPHP 3.1.2 介绍及安装
    【算法】高效计算n的m次方
    linux下解压.zip压缩包出现乱码的问题解决
    马哥linux笔记--重定向
    JavaScript的基本知识
    repeater做删除前弹窗询问
    网页中图片路径错误时显示默认图片方法
    添加分页
    javascript类型转换
  • 原文地址:https://www.cnblogs.com/gcczhongduan/p/4340141.html
Copyright © 2020-2023  润新知