使用nodejs爬取前程无忧前端技能排行
发布时间 - 2026-01-11 01:00:19 点击率:次最近准备换工作,需要更新一下技能树。为做到有的放矢,想对招聘方的要求做个统计。正好之前了解过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爬取中关村的在线电瓶车信息
# 小编
# 自己的
# 客户端
# 几个
# 会有
# 出了
# 有的放矢
# 给大家
# 要用
# 做个
# 不支持
# 不需
# 再用
# 跟在
# 先用
# 还需
# 所述
# 每条
# 数据包
# 给我留言
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
BootStrap整体框架之基础布局组件
香港服务器部署网站为何提示未备案?
Laravel如何实现多对多模型关联?(Eloquent教程)
常州企业网站制作公司,全国继续教育网怎么登录?
Laravel的.env文件有什么用_Laravel环境变量配置与管理详解
Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理
如何实现javascript表单验证_正则表达式有哪些实用技巧
Java类加载基本过程详细介绍
PHP正则匹配日期和时间(时间戳转换)的实例代码
西安专业网站制作公司有哪些,陕西省建行官方网站?
IOS倒计时设置UIButton标题title的抖动问题
Laravel如何配置和使用缓存?(Redis代码示例)
音响网站制作视频教程,隆霸音响官方网站?
Windows10如何更改计算机工作组_Win10系统属性修改Workgroup
Laravel观察者模式如何使用_Laravel Model Observer配置
Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
如何在云指建站中生成FTP站点?
Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载
香港网站服务器数量如何影响SEO优化效果?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)
Laravel如何与Pusher实现实时通信?(WebSocket示例)
如何快速搭建FTP站点实现文件共享?
移动端脚本框架Hammer.js
小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像
北京专业网站制作设计师招聘,北京白云观官方网站?
怎样使用JSON进行数据交换_它有什么限制
详解Android中Activity的四大启动模式实验简述
如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】
网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?
Laravel如何实现模型的全局作用域?(Global Scope示例)
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
教学论文网站制作软件有哪些,写论文用什么软件
?
佛山网站制作系统,佛山企业变更地址网上办理步骤?
Python图片处理进阶教程_Pillow滤镜与图像增强
Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置
制作公司内部网站有哪些,内网如何建网站?
大学网站设计制作软件有哪些,如何将网站制作成自己app?
Linux系统命令中tree命令详解
Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势
海南网站制作公司有哪些,海口网是哪家的?
Laravel API资源类怎么用_Laravel API Resource数据转换
Laravel中间件如何使用_Laravel自定义中间件实现权限控制
如何选择可靠的免备案建站服务器?
如何快速选择适合个人网站的云服务器配置?
详解Oracle修改字段类型方法总结
绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信
Python并发异常传播_错误处理解析【教程】
如何快速搭建高效WAP手机网站吸引移动用户?

