全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

使用nodejs爬取前程无忧前端技能排行

最近准备换工作,需要更新一下技能树。为做到有的放矢,想对招聘方的要求做个统计。正好之前了解过nodejs,所以做了个爬虫搜索数据。

具体步骤:

1.  先用fiddler分析请求需要的header和body。

2.  再用superagent构建上述数据发送客户端请求。

3.  最后对返回的数据使用cheerio整理。

折腾了几个晚上,只搞出了个架子,剩余工作等有时间再继续开发。

/*使用fiddler抓包,需要配置lan代理,且设置如下参数*/
process.env.https_proxy = "http://127.0.0.1:8888";
process.env.http_proxy = "http://127.0.0.1:8888";
process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0";
/*使用到的模块*/
var request = require('superagent');  //发送客户端请求
require('superagent-proxy')(request);  //使用代理发送请求
var cheerio = require('cheerio');    //以jq类似的方法操作返回的字符,不需要用正则
require('superagent-charset')(request);//node不支持gbk,gb2312,this will add request.Request.prototype.charset.
var async = require('async');      //异步流控制模块
var fs = require('fs');
/*相关参数,通过fiddler抓包后复制过来*/
var ws = fs.createWriteStream('res.html',{flags:'w+'}); //a+追加的读写模式,w+覆盖
var loginUrl = "https://login.51job.com/login.php";
var searchUrl = "http://search.51job.com/jobsearch/search_result.php";
var queryStrings = "fromJs=1&jobarea=020000&keyword=%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91&keywordtype=2&lang=c&stype=2&postchannel=0000&fromType=1&confirmdate=9";
var loginForms = {
  lang: 'c',
  action: 'save',
  from_domain: 'i',
  loginname: '***',  //自己的用户名和密码
  password: '***',
  verifycode: '',
  isread: 'on'
};
var searchForms = {
  lang: 'c',
  stype: '2',
  postchannel: '0000',
  fromType: '1',
  line: '',
  confirmdate: '9',
  from: '',
  keywordtype: '2',
  keyword: '%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91',
  jobarea: '020000',
  industrytype: '',
  funtype: ''
};
var searchFormsString='lang=c&stype=2&postchannel=0000&fromType=1&line=&confirmdate=9&from=&keywordtype=2&keyword=%C7%B0%B6%CB%BF%AA%B7%A2&jobarea=020000&industrytype=&funtype=';
var proxy0 = process.env.https_proxy;
var proxy = process.env.http_proxy;
const agent = request.agent();     //agent()方法产生的实例会保存cookie供后续使用
request.post(loginUrl).proxy(proxy0).send(loginForms).end(function (err,res0) {
  agent.post(searchUrl)
    .proxy(proxy)          //proxy()方法需紧跟在method方法之后调用,否则fiddler抓不到数据包
    .type('application/x-www-form-urlencoded')
    .query(queryStrings)      //使用字符串格式
    .send(searchFormsString)
    .charset('gbk')        //通过charset可知编码字符格式,不设置会有乱码
    .end(function (err, res) {
      /* 以下是处理返回数据的逻辑代码*/
      var $ = cheerio.load(res.text);  //res.text是返回的报文主体
      async.each($('.el.title').nextAll('.el'), function(v, callback) {
        //将多余的内容删除,保留岗位、公司链接
        $(v).prepend($(v).find('.t1 a'));
        $(v).find('.t1').remove();
        ws.write($.html(v), 'utf8');
      }, function(err) {
        console.log(err);
      });
      console.log('successful');
    })
});
//jquery内置document元素为root,cheerio需要通过load方法传入,然后用选择器查找指定元素,再执行相应操作。
// $.html(el);静态方法,返回el元素的outerHtml
//TODO
// 1.当前只请求到一页数据,还需构建所有页数的请求列表
// 2.向每条数据的岗位链接发送请求,获取技能关键字,存入文件中
// 3.node中io操作是异步的,且没有锁的概念,如何并发地向同一个文件正确地写入数据

结果显示如下:

以上所述是小编给大家介绍的使用nodejs爬前程无忧前端技能排行,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!


# nodejs  # 爬前程无忧  # 前端技能  # node+experss实现爬取电影天堂爬虫  # 利用node.js写一个爬取知乎妹纸图的小爬虫  # 利用Node.js制作爬取大众点评的爬虫  # nodejs实现爬取网站图片功能  # node爬取微博的数据的简单封装库nodeweibo使用指南  # Node.js环境下编写爬虫爬取维基百科内容的实例分享  # node.js爬虫爬取拉勾网职位信息  # 手把手教你用Node.js爬虫爬取网站数据的方法  # 利用node.js爬取指定排名网站的JS引用库详解  # node.js爬取中关村的在线电瓶车信息  # 小编  # 自己的  # 客户端  # 几个  # 会有  # 出了  # 有的放矢  # 给大家  # 要用  # 做个  # 不支持  # 不需  # 再用  # 跟在  # 先用  # 还需  # 所述  # 每条  # 数据包  # 给我留言 


相关文章: 建站之星安装后如何配置SEO及设计样式?  TestNG的testng.xml配置文件怎么写  宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?  制作企业网站建设方案,怎样建设一个公司网站?  ,在苏州找工作,上哪个网站比较好?  如何设计高效校园网站?  武清网站制作公司,天津武清个人营业执照注销查询系统网站?  如何在香港服务器上快速搭建免备案网站?  网站制作难吗安全吗,做一个网站需要多久时间?  零服务器AI建站解决方案:快速部署与云端平台低成本实践  如何选择靠谱的建站公司加盟品牌?  如何在云虚拟主机上快速搭建个人网站?  武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?  微课制作网站有哪些,微课网怎么进?  如何配置支付宝与微信支付功能?  建站之星伪静态规则如何正确配置?  小说建站VPS选用指南:性能对比、配置优化与建站方案解析  常州企业网站制作公司,全国继续教育网怎么登录?  高防服务器租用指南:配置选择与快速部署攻略  如何用景安虚拟主机手机版绑定域名建站?  寿县云建站:智能SEO优化与多行业模板快速上线指南  建站之星安装步骤有哪些常见问题?  长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?  内部网站制作流程,如何建立公司内部网站?  测试制作网站有哪些,测试性取向的权威测试或者网站?  php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】  西安大型网站制作公司,西安招聘网站最好的是哪个?  建站主机是什么?如何选择适合的建站主机?  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  广东企业建站网站优化与SEO营销核心策略指南  大学网站设计制作软件有哪些,如何将网站制作成自己app?  如何高效利用亚马逊云主机搭建企业网站?  广州网站建站公司选择指南:建站流程与SEO优化关键词解析  枣阳网站制作,阳新火车站打的到仙岛湖多少钱?  制作网站的公司有哪些,做一个公司网站要多少钱?  如何在云主机上快速搭建多站点网站?  上海网站制作开发公司,上海买房比较好的网站有哪些?  宝塔新建站点报错如何解决?  如何快速搭建高效香港服务器网站?  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  沈阳制作网站公司排名,沈阳装饰协会官方网站?  网页设计网站制作软件,microsoft office哪个可以创建网页?  如何通过西部建站助手安装IIS服务器?  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  ,有什么在线背英语单词效率比较高的网站?  建站之星安装模板失败:服务器环境不兼容?  如何用VPS主机快速搭建个人网站?  制作网站外包平台,自动化接单网站有哪些?  北京建设网站制作公司,北京古代建筑博物馆预约官网?  建站上传速度慢?如何优化加速网站加载效率? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。