1. 設為首頁   文化中國網歡迎您~!

          Python實現人事自動打卡!還怕忘記打卡被叼?自動簽到與簽退

          我司使用的打卡軟件是 i 人事,不過我這記性,經常漏了打卡簽退,定了鬧鐘都會忘,今天又被老大屌了。于是準備抓一下簽到接口,利用 crontab 來實現自動簽到簽退。

          環境配置

          這里使用的是 Fiddler 進行抓包,Fiddler 是一個 HTTP 調試代理工具,以代理服務器的形式實現對網絡數據流的監聽。之所以沒有用 Wireshark,一是因為我不是很熟悉 wireshark 的篩選器,二是因為本文使用模擬器(手機應用后臺流量多,不便于分析)來抓包,代理服務器方式更方便。

          安裝Fiddler

          先安裝 Fiddler( 官網地址 ),安裝完成之后需要安裝 fiddlercertmaker 證書生成工具( 官網地址 )

          Fiddler配置

          如圖,打開Fiddler,Tools 選擇 Fiddler Options,將圖中所標識地方勾選,配置后點擊 OK 保存并重啟 Fiddler

          再次打開該選項卡,點擊 Action 生成證書到桌面(文件名 FiddlerRoot.cer)

          將該證書文件上傳到模擬器即可。

          模擬器配置

          記錄 Windows 當前網卡的 IP 備用。

          打開模擬器,在模擬器內的系統設置中選擇 “安全”,選擇 “從 SD 卡安裝”,選擇前面上傳的證書,安裝即可。(過程中會要求設置屏保密碼,設置即可)

          選擇模擬器內的 WiFi 連接,長按當前的 WiFi,選擇修改網絡,選擇手動配置代理,地址填前面記錄的 Windows 本地 IP,端口為 8888,保存后重啟模擬器即可。

          開始抓包

          配置過濾器

          打開 Fiddler 后,打開模擬器,這時候在 Fiddler 會監聽到大量的流量信息,便于查找,我們需要使用過濾器,如圖,在 Fiddler 界面右側,選擇 “Filters”并勾選,選擇 “Use Filters”,在 “Hosts” 項目中,選擇 “Show only the following Hosts”,并填入 “www.ihr360.com” 這樣能過濾掉除 i 人事以外的域名流量信息,同時,在 “Request Headers” 中,勾選 “Show only if URL contains”,填入 “gateway/attendance/aggregate/attendance/api/sign/doSign” ,點擊右上角的 Actions,選擇 “Run Filterset now” 以生效過濾器。在 Fiddler 左側的流量信息欄中,使用 Ctrl + X 清除當前所有流量信息。

          模擬器簽到

          將模擬器的模擬定位定位到需要打卡的位置,打開 i 人事,點擊考勤打卡,打卡簽到,這時候在 Fiddler 中會出現一條監聽到的請求,雙擊打開,如圖所示,

          可以看到,實際上打卡簽到動作就是一條 POST 請求。我們了解了這條 POST 請求的基本內容后就可以利用 Python 的 requests 模塊來模擬提交了。

          模擬請求

          模擬 POST 請求很簡單,這里就不多說,直接貼代碼(很爛=.=! ,能用就行啦…勿噴…):

          #!/usr/bin/env python3# www.iots.vip# Alliot# 2020-1-8import requestsimport jsonimport smtplibfrom email.mime.text import MIMETextfrom email.utils import formataddrfrom time import strftime, localtime# 忽略 requests 請求認證警告requests.packages.urllib3.disable_warnings()# 郵件設置server = 'smtp.163.com'port = '25'sender = '發件人郵箱'passwd = '密碼(授權碼)'receiver = '收件人'# i 人事簽到接口地址url = "https://www.ihr360.com/gateway/attendance/aggregate/attendance/api/sign/doSign"# 抓包簽到請求頭headersValue = {    'Cookie': 'SESSION=XXXXXXXXXXXXXX; Path=/; HttpOnly',    'accept': 'application/json;charset=UTF-8',    'appKey': 'com.irenshi.personneltreasure',    'appVersion': 'XXXX',    'osVersion': 'XXXX',    'udid': 'XXXXXX',    'user-agent': 'IRENSHI_APP_AGENT',    'os': 'Android',    'irenshilocale': 'zh_CN',    'Content-Type': 'application/json; charset=utf-8',    'Content-Length': '272',    'Host': 'www.ihr360.com',    'Connection': 'Keep-Alive',    'Accept-Encoding': 'gzip',}# 抓包請求 jsonjsonValue = {    "deviceToken": " ",    "deviceType": "NORMAL",    "latitude": XXX,    "locationName": "XXX",    "longitude": XXX,    "phoneName": "MI6",    "signSource": "APP",    "wifiMac": "XXX",    "wifiName": "Alliot",}# 簽到方法def doSign(url, jsonValue, headersValue):    r = requests.post(url, json=jsonValue, headers=headersValue, verify=False)    global results    results = json.loads(r.text)    print(strftime("%Y-%m-%d %H:%M:%S", localtime()))    return results# 郵件提醒方法def sendMail(server, port, sender, passwd, msg):    smtp = smtplib.SMTP()    smtp.connect(server, port)    smtp.login(sender, passwd)    smtp.sendmail(msg['From'], msg['To'], msg.as_string())    smtp.quit()    print('郵件發送成功email has send out !')def newMail(status):    msg = MIMEText(str(results), 'plain', 'utf-8')    msg['From'] = formataddr(["AlliotSigner", sender])    msg['To'] = formataddr(["Alliot", receiver])    if status == None:        msg['Subject'] = '打卡失敗-_-!'        print("打卡失敗")    else:        msg['Subject'] = '自動打卡成功'        print("打卡成功")    sendMail(server, port, sender, passwd, msg)# 簽到并郵件通知結果,不用通知則改為 doSign(url, jsonValue, headersValue) 即可newMail(doSign(url, jsonValue, headersValue)["data"])# doSign(url, jsonValue, headersValue)

          修改其中的配置為上文抓到的數據即可(這里注意, headersValue 請求頭為字典格式, jsonValue 則為 Json 格式,執行報錯的時候檢查一下是否是格式錯誤。)、

          私信小編01 領取完整項目代碼!

          上傳到服務器中,執行:

          python3 ihr.py # 你的文件名

          執行后,打開 i 人事查看是否成功產生一次簽到記錄,成功即可添加進計劃任務。

          定時執行

          利用 crontab 來實現自動執行。關于 crontab 的具體使用,可見 Linux下crontab的使用與注意事項 | Alliot’s blog

          我是定義每周工作日的 8 點 18 點打卡,crontab 配置為:

          0 8,18 * * mon,tue,wed,thu,fri,sat /usr/bin/python3 /alliot/ihr.py>>/alliot/ihr_log.txt

          后記

          整個流程很簡單粗暴,其實一般后臺都是能看出來的,因為每次的簽到位置都是一樣,所以如果想要逼真一點,可以在請求中經緯度、位置名里使用范圍的隨機數等等… 不過,還是那句話: 可以,但沒必要。

          推薦閱讀:葉紫網
          好运来 www.jfsjt.com:威信县| www.thevargasgroup.net:惠安县| www.222qa.com:微山县| www.busongqi.com:汽车| www.ramadawg.com:永修县| www.yt9168.com:莒南县| www.besttech-jy.com:柘城县| www.shank-tank.net:庆城县| www.brysonadventures.com:抚顺县| www.philjohannes.com:灌阳县| www.rcybgg.com:邓州市| www.aaotimepasskarain.com:南昌县| www.utahsbusinessdirectory.com:上思县| www.simuladorpoupanca.com:汨罗市| www.shatac.com:锦州市| www.polperrocornwall.com:丹江口市| www.galbia.com:黑河市| www.oldschoolvans.com:华池县| www.chuwenxuan.com:正宁县| www.201853.com:江华| www.kates-garden.com:南昌县| www.hhlbw.cn:景德镇市| www.thehopedesign.com:湘潭市| www.mersta.com:衡山县| www.lemonadedoll.com:安陆市| www.sharansoft.com:青海省| www.thehelvetia.com:乌苏市| www.es5u.com:固原市| www.anotherspace2.com:萝北县| www.j0662.com:武清区| www.ligu-coating.com:通州区| www.02art.com:定州市| www.hearingspecialistcarolina.com:南阳市| www.assamnaukri.com:元谋县| www.tjskexin.com:三门县| www.electricmassagechair.org:濮阳县| www.bnkft.com:柳林县| www.himanidalmia.com:墨脱县| www.egehannakliyat.com:东平县| www.guitarquest.net:平远县| www.pd553.com:怀化市| www.digishoppy.com:定结县| www.thedrugtest.net:隆化县| www.jp-daigo.com:玉门市| www.xizig.com:万全县| www.zhugangfamen.com:呼伦贝尔市| www.chameleon-dating.com:通榆县| www.surprisegiftt.com:西林县| www.conventionavenue.com:井冈山市| www.chinagoodbuy.com:柏乡县| www.hg20704.com:平罗县| www.gs533.com:满洲里市| www.tjhct.com:阳山县| www.906765.com:灵武市| www.deeblick.com:柳河县| www.jnwfm.cn:兰溪市| www.wfhtdr.com:呼图壁县| www.guxingrun.com:临沭县| www.fsxianxin.com:宁明县| www.philjohannes.com:余庆县| www.srmcinc.org:吉林省| www.thegreatmuseum.net:郸城县| www.spielothekspiele.com:禄劝| www.wainini.com:岳普湖县| www.aaagascalculator.com:红桥区| www.dlzhutan.com:祁连县| www.qdtingmei.com:增城市| www.vsdtv.com:集安市| www.xkfan.com:巧家县| www.xhboat.com:英山县| www.arecipesite.com:兰坪| www.accentata.com:利津县| www.jlswp.com:大安市| www.dirload.com:沙河市| www.cp3309.com:潜山县| www.jjmatransportation.com:彝良县| www.aggressive-lawyers.com:唐海县| www.cryptosharefund.com:河东区| www.erausquyn.com:繁峙县| www.102371.com:阿拉善右旗| www.ideabridgepromos.com:嫩江县| www.carolinemonick.com:区。| www.ftb4.com:池州市| www.dannyquattro.com:榆树市|