苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 6450|回复: 5

[HttpHelper] 网站测试结果和代码生成器生成的代码请求结果不一样,请求飞哥帮忙!

[复制链接]
发表于 2019-8-21 09:49:57 | 显示全部楼层 |阅读模式
http://mobile.yangkeduo.com/goods.html?goods_id=735873502

这个网址,通过网站的测试工具(默认设置,不跳转),可以获取到跳转之前的HTML源码。
但是生成代码后,复制代码去请求,请求的结果是跳转后要求登录的页面HTML。
请飞哥帮忙解决一下,万分感谢。

同样的问题苏飞开发助手2.0请求的HTML也是跳转后的HTML(已经设置自动跳转false)


1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
发表于 2019-8-21 10:48:03 | 显示全部楼层
貌似和本地电脑环境有关系吧,线上的是框架,你用的是类吧,应该会有差别,或者你发一下你使用我线上获取一的代码我看看是什么样的,我这边显示会跳转,用的也是线上的。
 楼主| 发表于 2019-8-21 11:11:21 | 显示全部楼层
HttpHelper http = new HttpHelper();  
HttpItem item = new HttpItem()  
{  
    URL = "http://mobile.yangkeduo.com/goods.html?goods_id=735873502",//URL     必需项  
    Method = "GET",//URL     可选项 默认为Get  
    Timeout = 100000,//连接超时时间     可选项默认为100000  
    ReadWriteTimeout = 30000,//写入Post数据超时时间     可选项默认为30000  
    IsToLower = false,//得到的HTML代码是否转成小写     可选项默认转小写  
    Cookie = "",//字符串Cookie     可选项  
    UserAgent = "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:18.0) Gecko/20100101 Firefox/18.0",//用户的浏览器类型,版本,操作系统     可选项有默认值  
    Accept = "text/html, application/xhtml+xml, */*",//    可选项有默认值  
    ContentType = "text/html",//返回类型    可选项有默认值  
    Referer ="http://www.sufeinet.com",//来源URL     可选项  
    Allowautoredirect = False,//是否根据301跳转     可选项  
    AutoRedirectCookie = False,//是否自动处理Cookie     可选项  
    //CerPath = "d:\123.cer",//证书绝对路径     可选项不需要证书时可以不写这个参数  
    //Connectionlimit = 1024,//最大连接数     可选项 默认为1024  
    Postdata = "",//Post数据     可选项GET时不需要写  
    //ProxyIp = "192.168.1.105:2020",//代理服务器ID     可选项 不需要代理 时可以不设置这三个参数  
    //ProxyPwd = "123456",//代理服务器密码     可选项  
    //ProxyUserName = "administrator",//代理服务器账户名     可选项  
    ResultType = ResultType.String,//返回数据类型,是Byte还是String  
};  
HttpResult result = http.GetHtml(item);  
string html = result.Html;  
string cookie = result.Cookie;  
         
  
        /// <summary>  
        /// 字节数组生成图片  
        /// </summary>  
        /// <param name="Bytes">字节数组</param>  
        /// <returns>图片</returns>  
        private Image byteArrayToImage(byte[] Bytes)  
        {  
            MemoryStream ms = new MemoryStream(Bytes);  
            return Bitmap.FromStream(ms,true);  
        }  
 楼主| 发表于 2019-8-21 11:11:59 | 显示全部楼层
  • HttpHelper http = new HttpHelper();  
  • HttpItem item = new HttpItem()  
  • {  
  •     URL = "http://mobile.yangkeduo.com/goods.html?goods_id=735873502",//URL     必需项  
  •     Method = "GET",//URL     可选项 默认为Get  
  •     Timeout = 100000,//连接超时时间     可选项默认为100000  
  •     ReadWriteTimeout = 30000,//写入Post数据超时时间     可选项默认为30000  
  •     IsToLower = false,//得到的HTML代码是否转成小写     可选项默认转小写  
  •     Cookie = "",//字符串Cookie     可选项  
  •     UserAgent = "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:18.0) Gecko/20100101 Firefox/18.0",//用户的浏览器类型,版本,操作系统     可选项有默认值  
  •     Accept = "text/html, application/xhtml+xml, */*",//    可选项有默认值  
  •     ContentType = "text/html",//返回类型    可选项有默认值  
  •     Referer ="http://www.sufeinet.com",//来源URL     可选项  
  •     Allowautoredirect = False,//是否根据301跳转     可选项  
  •     AutoRedirectCookie = False,//是否自动处理Cookie     可选项  
  •     //CerPath = "d:\123.cer",//证书绝对路径     可选项不需要证书时可以不写这个参数  
  •     //Connectionlimit = 1024,//最大连接数     可选项 默认为1024  
  •     Postdata = "",//Post数据     可选项GET时不需要写  
  •     //ProxyIp = "192.168.1.105:2020",//代理服务器ID     可选项 不需要代理 时可以不设置这三个参数  
  •     //ProxyPwd = "123456",//代理服务器密码     可选项  
  •     //ProxyUserName = "administrator",//代理服务器账户名     可选项  
  •     ResultType = ResultType.String,//返回数据类型,是Byte还是String  
  • };  
  • HttpResult result = http.GetHtml(item);  
  • string html = result.Html;  
  • string cookie = result.Cookie;  
  •          
  •   
  •         /// <summary>  
  •         /// 字节数组生成图片  
  •         /// </summary>  
  •         /// <param name="Bytes">字节数组</param>  
  •         /// <returns>图片</returns>  
  •         private Image byteArrayToImage(byte[] Bytes)  
  •         {  
  •             MemoryStream ms = new MemoryStream(Bytes);  
  •             return Bitmap.FromStream(ms,true);  
  •         }  

 楼主| 发表于 2019-8-21 11:13:07 | 显示全部楼层
在网站测试是可以的(跳转前),生成代码后请求后是跳转的。
 楼主| 发表于 2019-8-21 16:02:53 | 显示全部楼层
站长苏飞 发表于 2019-8-21 10:48
貌似和本地电脑环境有关系吧,线上的是框架,你用的是类吧,应该会有差别,或者你发一下你使用我线上获取一 ...

帮忙看下什么原因呢
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2024-12-25 16:06

© 2014-2021

快速回复 返回顶部 返回列表