通过程序对远程url中的源码的获取

博客介绍了两种获取网页源码的方法。一是使用WebClient,有DownloadData直接获取和OpenRead通过流读取两种方式,流方式适合大数据源url,数据大时可分步获取以优化性能;二是用WebRequest和WebResponse配合,通过GetResponse方法获取,读取数据流时以256字节为单位循环读取可减少性能影响。
  • 第一种方法是通过WebClient 来获取 

                     其中有两种方法:

                     1利用WebClien的DownloadData方法,直接获取。

   string PageUrl = "http://inhe.net";
   WebClient wc = new WebClient();
   wc.Credentials = CredentialCache.DefaultCredentials;

   ///方法一:
     Byte[] pageData = wc.DownloadData(PageUrl);
     Response.Write(Encoding.UTF8.GetString(pageData));

         2  利用WebClient的OpenRead 方法得到一个数据流,然后通过流数据来读取(我觉得这种方法适合大数据的源成url) 呵呵 ,不知道说得对不对?  

/// 方法二

    Stream resStream = wc.OpenRead(PageUrl);
    StreamReader sr = new StreamReader(resStream,System.Text.Encoding.Default);
    ContentHtml.Text = sr.ReadToEnd();
    resStream.Close();

当然这种用流的方式还是只是用于数据不大的情况,如果数据很大的话,由于我们开了个流,就可以采取措施。分步的来获取,不至于影响到程序的性能

  • 第二种方法是用WebRequest 和 WebResponse来配合得到,具体流程是:

                           通过WebRequest 的 GetResponse方法将页面的源码传入WebResponse之中,然后在返  回一个Stream 通过读取这个stream来得到源代码

string Url = "Http://inhe.net";
   string StrReturn = "";
   WebResponse result = null;   
   try
   {
    WebRequest req = WebRequest.Create(Url);   
    result = req.GetResponse();
    Stream ReceiveStream = result.GetResponseStream();    
    Encoding encode = System.Text.Encoding.GetEncoding("GB2312");
    StreamReader sr = new StreamReader( ReceiveStream,encode);
    Char[] read = new Char[256];
    int count = sr.Read(read, 0, 256);
    while (count > 0)
    {
     String str = new String(read, 0, count);
     StrReturn += str;
     count = sr.Read(read, 0, 256);
    }
   }
   catch(Exception ee)
   {
    StrReturn += e.ToString();
    StrReturn += "找不到请求 URI,或者它的格式不正确";
   }
   finally
   {
    if ( result != null )
    {
     result.Close();
    }
   }
   Response.Write( @StrReturn.Trim());

其中这里有一个小的技巧 读取数据流时,这段代码时让它以256字节为单位来循环读取,这样当数据较大时,就不会过大的影响到程序的性能

呵呵 不知道我说的对不对,欢迎大家和我讨论

源码地址: https://pan.quark.cn/s/d1f41682e390 miyoubiAuto 米游社每日米游币自动化Python脚本(务必使用Python3) 8更新:更换cookie的获取地址 注意:禁止在B站、贴吧、或各大论坛大肆传播! 作者已退游,项目不维护了。 如果有能力的可以pr修复。 小引一波 推荐关注几个非常可爱有趣的女孩! 欢迎B站搜索: @嘉然今天吃什么 @向晚大魔王 @乃琳Queen @贝拉kira 第三方库 食用方法 下载源码 在Global.py中设置米游社Cookie 运行myb.py 本地第一次运行时会自动生产一个文件储存cookie,请勿删除 当前仅支持单个账号! 获取Cookie方法 浏览器无痕模式打开 http://user.mihoyo.com/ ,登录账号 按,打开,找到并点击 按刷新页面,按下图复制 Cookie: How to get mys cookie 当触发时,可尝试按关闭,然后再次刷新页面,最后复制 Cookie。 也可以使用另一种方法: 复制代码 浏览器无痕模式打开 http://user.mihoyo.com/ ,登录账号 按,打开,找到并点击 控制台粘贴代码并运行,获得类似的输出信息 部分即为所需复制的 Cookie,点击确定复制 部署方法--腾讯云函数版(推荐! ) 下载项目源码和压缩包 进入项目文件夹打开命令行执行以下命令 xxxxxxx为通过上面方式或取得米游社cookie 一定要用双引号包裹!! 例如: png 复制返回内容(包括括号) 例如: QQ截图20210505031552.png 登录腾讯云函数官网 选择函数服务-新建-自定义创建 函数名称随意-地区随意-运行环境Python3....
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值