JS腳本實(shí)現(xiàn)定時(shí)到網(wǎng)站上簽到/簽退功能
之前介紹過(guò)使用temperMonkey屏蔽CSDN廣告的方法,主要就是要針對(duì)性地分析網(wǎng)站結(jié)構(gòu),然后用代碼去改變或者操作DOM。今天也一樣,我們需要觀察網(wǎng)頁(yè)結(jié)構(gòu),找到我們要操作的按鈕,觸發(fā)他的
click事件就可以了。下面以公司打卡簽到的網(wǎng)站為例,做一些壞壞的事情。本文讀者最好有一定的HTML和JavaScript基礎(chǔ)。
首先,想象一下你去簽到需要做什么:
- 打開(kāi)網(wǎng)站
- 登陸
- 點(diǎn)擊“簽到”按鈕
然后每一步我們都可以讓代碼幫我們?nèi)プ觥?/p>
0. 如何定時(shí)
這段代碼是核心,就是根據(jù)當(dāng)前時(shí)間和設(shè)定的時(shí)間做差值,來(lái)確定定時(shí)器的值
看懂這段代碼,后面的就都容易了。都是在利用定時(shí)器觸發(fā)callback。
// user setting
const SIGN_IN_TIME = "09:30:00"; // 簽到時(shí)間
const SIGN_OUT_TIME = "20:00:00"; // 簽退時(shí)間
// code implementation
logTime("code start running");
const now = new Date();
const today = now.getFullYear() + "-" + (now.getMonth() + 1) + "-" + now.getDate();
var signInTime = +new Date(`${today} ${SIGN_IN_TIME}`);
logTime("signInTime", new Date(signInTime));
var signOutTime = +new Date(`${today} ${SIGN_OUT_TIME}`);
logTime("signOutTime", new Date(signOutTime));
// diff in or out
if (now > signInTime && now < signOutTime) {
// ready to sign out for today
console.log("Seconds to sign out for today: " + (signOutTime - now) / 1000);
setTimeout(callback, signOutTime - now);
} else {
// ready to sign in for tomorrow
signInTime = +signInTime + 60 * 60 * 24 * 1000;
console.log("Seconds to sign in for tomorrow: " + (signInTime - now) / 1000);
setTimeout(callback, signInTime - now);
}
function logTime(str, time = new Date()) {
console.log(`${str} -> ${time.getHours()}:${time.getMinutes()}:${time.getSeconds()}`);
}
1. 定時(shí)自動(dòng)打開(kāi)網(wǎng)站
因?yàn)榇蠖鄶?shù)網(wǎng)站都有,“長(zhǎng)時(shí)間未操作-自動(dòng)退出”的設(shè)置。所以我們要在需要打卡的時(shí)候再打開(kāi)網(wǎng)站。
在電腦本地跑一個(gè)程序,使用定時(shí)器。這里跑一個(gè)node程序:
const open = require('open');
logTime("Start Runing");
// user setting
const SIGN_IN_TIME = "09:30:00";
const SIGN_OUT_TIME = "20:20:00";
// code implementation
const openBrowser = async () => {
await open('http://172.10.80.42');
};
logTime("code start running");
const now = new Date();
const today = now.getFullYear() + "-" + (now.getMonth() + 1) + "-" + now.getDate();
var signInTime = +new Date(`${today} ${SIGN_IN_TIME}`);
logTime("signInTime", new Date(signInTime));
var signOutTime = +new Date(`${today} ${SIGN_OUT_TIME}`);
logTime("signOutTime", new Date(signOutTime));
// diff in or out
if (now > signInTime && now < signOutTime) {
// ready to sign out for today
console.log("Seconds to sign out for today: " + (signOutTime - now) / 1000);
setTimeout(openBrowser, signOutTime - now);
} else {
// ready to sign in for tomorrow
signInTime = +signInTime + 60 * 60 * 24 * 1000;
console.log("Seconds to sign in for tomorrow: " + (signInTime - now) / 1000);
setTimeout(openBrowser, signInTime - now);
}
function logTime(str, time = new Date()) {
console.log(`${str} -> ${time.getHours()}:${time.getMinutes()}:${time.getSeconds()}`);
}
2. 自動(dòng)登錄
這個(gè)重點(diǎn)還是在于找到需要填入內(nèi)容的DOM元素
(function() {
'use strict';
// login
document.querySelector("#loginid").value = "用戶(hù)名";
document.querySelector("#userpassword").value = "密碼";
document.querySelector("#login").click();
})();
3. 定時(shí)點(diǎn)擊按鈕
這一步最重要的是要準(zhǔn)確找到按鈕,檢查元素慢慢查找吧。
其次,設(shè)定好簽到和簽退的時(shí)間,只有固定時(shí)間才會(huì)自動(dòng)簽到,防止每次登陸進(jìn)來(lái)自動(dòng)簽到或簽退,這樣太頻繁被發(fā)現(xiàn)。
(function() {
'use strict';
// user setting
const SIGN_IN_TIME = "09:00:00";
const SIGN_OUT_TIME = "21:00:00";
// code implementation
logTime("code start running");
const now = new Date();
const today = now.getFullYear()+"-"+(now.getMonth()+1)+"-"+now.getDate();
var signInTime = +new Date(`${today} ${SIGN_IN_TIME}`);
logTime("signInTime", new Date(signInTime));
var signOutTime = +new Date(`${today} ${SIGN_OUT_TIME}`);
logTime("signOutTime", new Date(signOutTime));
// diff in or out
if(now > signInTime && now < signOutTime) {
// ready to sign out for today
console.log("Seconds to sign out for today: " + (signOutTime - now)/1000);
setTimeout(signInorSignOut, signOutTime - now);
} else {
// ready to sign in for tomorrow
signInTime = +signInTime + 60 * 60 * 24 * 1000;
console.log("Seconds to sign in for tomorrow: " + (signInTime - now)/1000);
setTimeout(signInorSignOut, signInTime - now);
}
// signInorSignOut
function signInorSignOut(){
logTime(`signInButton clicked!`);
// 重點(diǎn)就在這兒了,找到網(wǎng)站的簽到按鈕#signInButton,并觸發(fā)他的點(diǎn)擊事件
document.querySelector("#signInButton").click();
}
function logTime(str, time=new Date()){
console.log(`${str} -> ${time.getHours()}:${time.getMinutes()}:${time.getSeconds()}`);
}
})();
4. 結(jié)束
一套操作,打完收工。每天下班的時(shí)候,不管是提前溜還是晚點(diǎn)到。記得本地開(kāi)一下程序:
node timer.js
到此這篇關(guān)于JS腳本實(shí)現(xiàn)定時(shí)到網(wǎng)站上簽到/簽退功能的文章就介紹到這了,更多相關(guān)js 定時(shí)簽到簽退內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS實(shí)現(xiàn)拼音(字母)匹配漢字(姓名)的示例代碼
這篇文章主要為大家詳細(xì)介紹了如何利用JavaScript實(shí)現(xiàn)拼音(字母)匹配(搜索)漢字(姓名)的效果,文中的示例代碼講解詳細(xì),感興趣的可以了解一下2023-04-04
canvas實(shí)現(xiàn)環(huán)形進(jìn)度條效果
本文主要介紹了canvas實(shí)現(xiàn)環(huán)形進(jìn)度條效果的實(shí)例。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-03-03
EditPlus中的正則表達(dá)式 實(shí)戰(zhàn)(4)
這篇文章主要介紹了 EditPlus中的正則表達(dá)式 實(shí)戰(zhàn)(4)的相關(guān)資料,需要的朋友可以參考下2016-12-12
Express代理轉(zhuǎn)發(fā)服務(wù)器實(shí)現(xiàn)
這篇文章主要為大家介紹了Express代理轉(zhuǎn)發(fā)服務(wù)器實(shí)現(xiàn)技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
跟我學(xué)習(xí)javascript的函數(shù)調(diào)用和構(gòu)造函數(shù)調(diào)用
跟我學(xué)習(xí)javascript的函數(shù)和構(gòu)造函數(shù)調(diào)用,主要包括三方面內(nèi)容函數(shù)調(diào)用、方法調(diào)用以及構(gòu)造函數(shù)調(diào)用,想要了解這些內(nèi)容的朋友千萬(wàn)不要錯(cuò)過(guò)下面的內(nèi)容。2015-11-11
javascript實(shí)現(xiàn)自動(dòng)輸出文本(打字特效)
文字如何實(shí)現(xiàn)打字的效果呢?在瀏覽網(wǎng)頁(yè)的時(shí)候也經(jīng)常能看到這種效果。本文給大家匯總介紹了幾種打字效果的文字特效,文字一個(gè)一個(gè)地打印在頁(yè)面上。2015-08-08
js實(shí)現(xiàn)調(diào)用網(wǎng)絡(luò)攝像頭及常見(jiàn)錯(cuò)誤處理
這篇文章主要介紹了js實(shí)現(xiàn)調(diào)用網(wǎng)絡(luò)攝像頭及常見(jiàn)錯(cuò)誤處理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
js 發(fā)個(gè)判斷字符串是否為符合標(biāo)準(zhǔn)的函數(shù)
判斷字符是不是ip和是不是數(shù)字的函數(shù)。2009-04-04

