这两年疫情,公司业务越来越差,必须得准备后路了,每天睡前都会在直聘上打一遍招呼,一直到打哈欠有睡意为止...,这样持续了一周,发现很难坚持,身为一名资深蜘蛛侠,怎么能这样下去呢?于是便萌生了对BOSS下手的念头。
boss的web端功能已经挺完整了,所以直接使用无头浏览器(puppetter/playwright)应该就能搞定了,然后再整几个简单的界面,应该就差不多了。先看前端它用了哪些技术。
熟悉的全家桶

经典的$

关于ajax请求需要注意的是boss使用了ajax代理,如果注入代码直接拦截原生ajax请求是拿不到response的。


消息传输格式protobuf,和抖音一样,找到定义文件就能解析了

要实现自动投简历,会用到以下一些接口,安全起见完整地址就不贴了,懂得搜一下就能找到。
职位搜索joblist.json,看字段名就能猜到什么意思
{
"code": 0,
"message": "Success",
"zpData": {
"resCount": 415,
"filterString": "",
"lid": "xxx",
"hasMore": true,
"jobList": [
{
"securityId": "xxx",
"bossAvatar": "xxx",
"bossCert": 3,
"encryptBossId": "xxx",
"bossName": "xxx",
"bossTitle": "渠道经理",
"goldHunter": 0,
"bossOnline": false,
"encryptJobId": "xxx",
"expectId": 0,
"jobName": "需求分析工程师",
"lid": "xxx",
"salaryDesc": "10-15K·13薪",
"jobLabels": [
"1-3年",
"本科"
],
"jobValidStatus": 1,
"iconWord": "",
"skills": [
"需求分析"
],
"jobExperience": "1-3年",
"daysPerWeekDesc": "",
"leastMonthDesc": "",
"jobDegree": "本科",
"cityName": "上海",
"areaDistrict": "浦东新区",
"businessDistrict": "张江",
"jobType": 0,
"proxyJob": 0,
"proxyType": 0,
"anonymous": 0,
"outland": 0,
"optimal": 0,
"iconFlagList": [],
"itemId": 1,
"city": xxx,
"isShield": 0,
"atsDirectPost": false,
"encryptBrandId": "xxx",
"brandName": "xxx",
"brandLogo": "xxx",
"brandStageName": "已上市",
"brandIndustry": "计算机软件",
"brandScaleName": "1000-9999人",
"welfareList": [
"零食下午茶",
"补充医疗保险",
"通讯补贴",
"五险一金",
"股票期权",
"带薪年假",
"员工旅游",
"节日福利",
"定期体检",
"交通补助",
"餐补",
"年终奖"
],
"industry": 100021,
"contact": false
}
]
}
}
获取简历attachment/checkbox
{
"code": 0,
"message": "Success",
"zpData": {
"supportVideoResume": false,
"resumeList": [
{
"resumeId": "xxx",
"showName": "全栈开发.docx",
"resumeSize": 10000,
"resumeSizeDesc": "34.9KB",
"suffixName": "docx",
"annexType": 0,
"uploadTime": "xxx",
"parserId": "xxx",
"syncStatus": 1,
"previewType": 1,
"restricted": false,
"cvId": "",
"securityStatus": 0,
"restrictedDays": -1,
"target": 0,
"nlpParserType": 1
},
{
"resumeId": "xxx",
"showName": "资深前端.docx",
"resumeSize": 12345,
"resumeSizeDesc": "34.9KB",
"suffixName": "docx",
"annexType": 0,
"uploadTime": "xxx",
"parserId": "xxxx",
"syncStatus": 1,
"previewType": 1,
"restricted": false,
"cvId": "",
"securityStatus": 0,
"restrictedDays": -1,
"target": 0,
"nlpParserType": 1
}
],
"videoResumeList": [],
"supportAnnexType": false,
"supportCommonResume": true,
"showUploadBtnType": false,
"complete": true,
"maxCount": 3,
"resumeCount": 3
}
}
打招呼friend/add post form
{
"code": 0,
"message": "Success",
"zpData": {
"showGreeting": true,
"securityId": "xxx",
"bossSource": 0,
"source": "",
"encBossId": "xxx",
"greeting": "个人觉得我和贵公司这一岗位很匹配,可以聊聊么?"
}
}
投简历exchange/request post form
分析这里面的消息类型,花了不少时间找规律,通过type+body.type+biztype基本就能确定唯一的消息类型
{
"from": {
"uid": xxx,
"name": "xxx",
"avatar": "xxx",
"company": "xxx",
"headImg": 8,
"certification": 3,
"source": 0
},
"to": {
"uid": xxx,
"name": "xxx",
"avatar": "xxx",
"company": "",
"headImg": 0,
"certification": 0,
"source": 0
},
"type": 1,
"mid": xxx,
"time": xxx,
"body": {
"type": 1,
"templateId": 1,
"headTitle": "",
"text": "好",
"sound": null,
"image": null,
"action": null,
"articles": [],
"notify": null,
"dialog": null,
"jobDesc": null,
"resume": null,
"redEnvelope": null,
"orderDetail": null,
"hyperLink": null,
"video": null,
"interview": null,
"jobShare": null,
"resumeShare": null,
"atInfo": null,
"sticker": null,
"chatShare": null,
"interviewShare": null,
"listCard": null,
"starRate": null,
"frame": null,
"multiImage": null,
"extend": ""
},
"offline": false,
"received": false,
"pushText": "xxx",
"taskId": 0,
"cmid": xxx,
"status": 0,
"uncount": 0,
"pushSound": 0,
"flag": xxx,
"encryptedBody": null,
"bizId": null,
"bizType": null,
"securityId": "xxx",
"isPresenceMsg": false,
"isSelf": false
}
下面是成品的效果
点击“添加账号”按钮

用boss直聘app扫码登录账号

出现boss账号头像代表登录成功

点击“求职计划”,然后点击右上角的“+”按钮

设置求职条件

注意事项:
点击“保存”按钮后,出现提示框,点击“开始”

接下来工具就会按顺序向符合条件的所有职位的boss打招呼和自动投简历了。
所有打过招呼的职位都会在列表里显示

本工具已将部分规范消息做了自动处理,比如简历投递邀请、交换联系方式请求等,而且会将其设置为已读,也就不会再出现在app的提醒里。但是有些非标准的消息,例如:“你做过XXX类项目吗”,这类消息你可以在app上手工回复,也可以在工具里为其配置自动回复规则,尽可能减少你的人工操作。可按下面的方式配置自动回复规则,点击“配置”按钮

点击“添加”按钮

填写规则

规则填写说明:
比如我要匹配消息内容中包含“简历”两个字的,然后执行自动发简历的操作,那么如下配置即可

点击“确定”,再点击“保存”。
多个关键字匹配有两种方式:


下面是一些常用回复规则供参考

左侧的上下箭头按钮用于调整优先级,每条消息都会按顺序从上到下匹配你设置好的规则,一旦完成匹配,就不会再匹配后面的规则。匹配不上的将会在app内提醒,你再手工回复。
目前我只需要每天晚上打开我的工具,让他自动去打招呼并处理消息,只有那些真正需要认真答复的消息才会出现app的提醒里,趁午休一一回复即可!
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("
我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden
这似乎非常适得其反,因为太多的gem会在window上破裂。我一直在处理很多mysql和ruby-mysqlgem问题(gem本身发生段错误,一个名为UnixSocket的类显然在Windows机器上不能正常工作,等等)。我只是在浪费时间吗?我应该转向不同的脚本语言吗? 最佳答案 我在Windows上使用Ruby的经验很少,但是当我开始使用Ruby时,我是在Windows上,我的总体印象是它不是Windows原生系统。因此,在主要使用Windows多年之后,开始使用Ruby促使我切换回原来的系统Unix,这次是Linux。Rub
华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o
C#实现简易绘图工具一.引言实验目的:通过制作窗体应用程序(C#画图软件),熟悉基本的窗体设计过程以及控件设计,事件处理等,熟悉使用C#的winform窗体进行绘图的基本步骤,对于面向对象编程有更加深刻的体会.Tutorial任务设计一个具有基本功能的画图软件**·包括简单的新建文件,保存,重新绘图等功能**·实现一些基本图形的绘制,包括铅笔和基本形状等,学习橡皮工具的创建**·设计一个合理舒适的UI界面**注明:你可能需要先了解一些关于winform窗体应用程序绘图的基本知识,以及关于GDI+类和结构的知识二.实验环境Windows系统下的visualstudio2017C#窗体应用程序三.
我们目前正在为ROR3.2开发自定义cms引擎。在这个过程中,我们希望成为我们的rails应用程序中的一等公民的几个类类型起源,这意味着它们应该驻留在应用程序的app文件夹下,它是插件。目前我们有以下类型:数据源数据类型查看我在app文件夹下创建了多个目录来保存这些:应用/数据源应用/数据类型应用/View更多类型将随之而来,我有点担心应用程序文件夹被这么多目录污染。因此,我想将它们移动到一个子目录/模块中,该子目录/模块包含cms定义的所有类型。所有类都应位于MyCms命名空间内,目录布局应如下所示:应用程序/my_cms/data_source应用程序/my_cms/data_ty
MIMO技术的优缺点优点通过下面三个增益来总体概括:阵列增益。阵列增益是指由于接收机通过对接收信号的相干合并而活得的平均SNR的提高。在发射机不知道信道信息的情况下,MIMO系统可以获得的阵列增益与接收天线数成正比复用增益。在采用空间复用方案的MIMO系统中,可以获得复用增益,即信道容量成倍增加。信道容量的增加与min(Nt,Nr)成正比分集增益。在采用空间分集方案的MIMO系统中,可以获得分集增益,即可靠性性能的改善。分集增益用独立衰落支路数来描述,即分集指数。在使用了空时编码的MIMO系统中,由于接收天线或发射天线之间的间距较远,可认为它们各自的大尺度衰落是相互独立的,因此分布式MIMO
遍历文件夹我们通常是使用递归进行操作,这种方式比较简单,也比较容易理解。本文为大家介绍另一种不使用递归的方式,由于没有使用递归,只用到了循环和集合,所以效率更高一些!一、使用递归遍历文件夹整体思路1、使用File封装初始目录,2、打印这个目录3、获取这个目录下所有的子文件和子目录的数组。4、遍历这个数组,取出每个File对象4-1、如果File是否是一个文件,打印4-2、否则就是一个目录,递归调用代码实现publicclassSearchFile{publicstaticvoidmain(String[]args){//初始目录Filedir=newFile("d:/Dev");Datebeg
通常,数组被实现为内存块,集合被实现为HashMap,有序集合被实现为跳跃列表。在Ruby中也是如此吗?我正在尝试从性能和内存占用方面评估Ruby中不同容器的使用情况 最佳答案 数组是Ruby核心库的一部分。每个Ruby实现都有自己的数组实现。Ruby语言规范只规定了Ruby数组的行为,并没有规定任何特定的实现策略。它甚至没有指定任何会强制或至少建议特定实现策略的性能约束。然而,大多数Rubyist对数组的性能特征有一些期望,这会迫使不符合它们的实现变得默默无闻,因为实际上没有人会使用它:插入、前置或追加以及删除元素的最坏情况步骤复