自动签到升级版(JS实现的每日定时任务)
公司规定每日签到两次;日子太安逸了,有时候中午居然会忘记签到……
于是,笔者寻思写一个自动签到的脚本;每天指定两个签到时段,每次打开页面,先检测当前是否为签到时段,如果在签到时段,则检查cookie中记录的值,确认该时段是否已经签到过了,巴拉巴拉…… 具体细节见流程图:

其中第一步调用的getCheckTime用来检测当前是否为签到时间,并返回当前时间距下一个时段的毫秒数,具体请见下面的流程图:

整个页面的代码如下,其中用到了笔者《JavaScript类库/组件/框架封装的总体结构》一文中提到的框架,封装了一个定时运行器,具体用法见注释:
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
- <meta name="author" content ="http://blog.csdn.net/NearEast"/>
- <title>check in page</title>
- <style type="text/css">
- .clear{
- clear:both;
- }
- .float{
- float:left;
- }
- </style>
- </head>
- <body>
- <div id="dInfo" class="float"></div>
- <div class="clear"></div>
- <div id="wrap">
- <iframe class="float" id='i_iframe1' name="n_iframe1" frameborder="0"></iframe>
- <iframe class="float" id='i_iframe2' name="n_iframe2" frameborder="0"></iframe>
- <form target="n_iframe1" name="loginform" method="post" action="http://192.168.19.11:8010/signin/signin.jsp">
- <input name="name" type='hidden' value='nidong' />
- <input name="passwd" type='hidden' value='11111111' />
- </form>
- </div>
- </body>
- <script type="text/javascript">
- <span style="white-space:pre"> </span>//封装一个定时运行器
- (function( window, undefined ) {
- var doc = window.document;
- var _checkTime, _func, _tip, _print;
- /**
- 初始化参数checkTime指定功能执行的时段,默认时间为'8:15'到'9:00',以及'12:35'到'14:00'两个时段
- checkTime应该是24小时制的,并且前面的绝对时间小于后面的绝对时间,例如'00:00:10'在'23:59'的前面
- func:在该时间段要执行的功能
- printFunc:日志信息的打印方法,默认为console.log方法打日志
- tip:要执行的功能的描述,tip可以是html语句,与printFunc结合可能达到各种效果,如例子所示
- */
- var checkUtil = function(conf) {
- _checkTime = conf.checkTime || ['8:15', '9:00', '12:35','14:00'];
- _func = conf.func;
- _tip = conf.tip || '功能执行';
- _print = conf.printFunc || console.log;
- _checkAndSet();
- };
- window.checkUtil= checkUtil;
- /**基于一个指定日期的时间base,通过'hh:mm:ss'格式的时间字符串,获取其毫秒时间
- 默认秒数为0
- */
- function _getMillisecond(base, str){
- var slices = str.split(':');
- if(!base instanceof Date || slices.length<2){
- alert('param error');
- return;
- }
- base.setHours(parseInt(slices[0]));
- base.setMinutes(parseInt(slices[1]));
- base.setSeconds(parseInt(slices[2]||'0'));
- return base.getTime();
- }
- /**计算是否处在签到时间段(flag==true),并返回距离下一次签到还有多久(毫秒)
- */
- function _getCheckTime(){
- var split = [], d = new Date(), curTime = new Date(d);
- d.setMilliseconds(0);
- for(var i=0;i<_checkTime.length;i++){
- split[i] = _getMillisecond(d, _checkTime[i]);
- }
- //最后一个元素为第一个元素加上24小时,意为循环到第二天
- split.push(24*3600*1000 + split[0]);
- split.unshift(_getMillisecond(d, '00:00:00'));
- var start, end;
- for(var i=0;i<split.length;i++){
- start = split[i];
- end = split[(i+1)%split.length];
- if(start<=curTime && curTime<=end){
- return{
- eclipse:end - curTime,
- flag:i%2==1/*第奇数个元素*/
- }
- }
- }
- return 'error';
- }
- function _addCookie(name, value) {
- var hours = 2;
- var exp = new Date();
- exp.setTime(exp.getTime() + hours * 60 * 60 * 1000);
- doc.cookie = name + "=" + escape(value) + ";expires="+ exp.toGMTString();
- }
- function _getCookie(name) {
- var arr, reg = new RegExp("(^| )" + name + "=([^;]*)(;|$)");
- if (arr = doc.cookie.match(reg))
- return unescape(arr[2]);
- else
- return null;
- }
- function _delCookie(name) {
- doc.cookie = name + "=n;expires=Thu, 01-Jan-70 00:00:01 GMT";
- }
- function _checkAndSet(){
- var ret = _getCheckTime();
- if(ret.flag){
- _print('当前为' + _tip + '时段');
- var checked = _getCookie('_checked');
- if(checked == 'true'){
- _print('本时段已' + _tip);
- }else{
- _print('现在执行' + _tip);
- _func();
- //////////////////////////print some information
- _addCookie('_checked', 'true');
- }
- }else{
- _print('当前非' + _tip + '时段');
- _delCookie('_checked');
- }
- setTimeout(function(){
- _checkAndSet();
- }, ret.eclipse);
- _print('将于' + ret.eclipse/1000 + '秒之后,执行_checkAndSet()');
- };
- })(window);
- window.onresize = function(){
- var frm = document.getElementById('i_iframe1');
- var frm2 = document.getElementById('i_iframe2');
- document.getElementById('wrap').style.height = document.documentElement.clientHeight+'px';
- frm.width=frm2.width='50%';//document.documentElement.clientWidth/2;
- frm.height=frm2.height='100%';//document.documentElement.clientHeight;
- };
- window.onload = function(){
- window.onresize();
- ///////////////////////////////As a single page
- checkUtil({func:function(){
- checkon();
- }, tip:'<a href="javascript:checkon();">签到</a>'
- , checkTime:['15:50', '15:50:10', '15:50:20','15:50:30']
- , printFunc:function(txt){
- document.getElementById('dInfo').innerHTML += txt+'<br>';
- }
- });
- }
- function checkon(){
- loginform.childNodes[1].value='nidong';
- loginform.target="n_iframe1";
- loginform.submit();
- loginform.childNodes[1].value='gengap';
- loginform.target="n_iframe2";
- loginform.submit();
- }
- </script>
- </html>
以上页面的js代码中,封装了一个checkUtil组件,可以用来定期执行任务。初始化参数checkTime中可以给出一天之内的多个时段,只要浏览器页面是打开状态,到了一定时间就将运行func参数指定的函数;如果天天不关机,就可以一劳永逸,不用操心func函数的运行了。不过虽然代码几经修改,存在别的小问题还是难免的,也不能完全依赖它做事;定期查看一下日志还是很必要的。
由于Chrome只支持online cookie,直接把代码粘到一个本地文件运行是无效的,其它浏览器不存在这个问题。
自动签到升级版(JS实现的每日定时任务)的更多相关文章
- 360每日自动签到,领取积分 (java httpclient4.x)
如何登陆360,并每日自动签到这次的难点主要集中在登陆这里了,开始抓包发现360登陆验证很麻烦,但是后来发现一个简单的方法.因为我安装了360安全卫士,发现点击那个金币的按钮能直接验证登陆,哈哈~所以 ...
- nodejs什么值得买自动签到自动评论定时任务
本项目是基于nodejs开发,实现的功能是,什么值得买自动签到,自动评论功能,自动发邮件,支持多人多账号运行 目的是为了,解放双手,轻松获取什么值得买的经验和积分,得到更高的等级,从而突破很会员等级限 ...
- 【开源】使用.Net Core和GitHub Actions实现哔哩哔哩每日自动签到、投币、领取奖励
BiliBiliTool是一个B站自动执行任务的工具,使用.NET Core编写,通过它可以实现B站帐号的每日自动观看.分享.投币视频,获取经验,每月自动领取会员权益.自动为自己充电等功能,帮助我们轻 ...
- Python 实现 T00ls 自动签到脚本(邮件+钉钉通知)
T00ls 每日签到是可以获取 TuBi 的,由于常常忘记签到,导致损失了很多 TuBi .于是在 T00ls 论坛搜索了一下,发现有不少大佬都写了自己的签到脚本,签到功能实现.定时任务执行以及签到提 ...
- selenium之数据驱动框架应用WPS个人中心自动签到
wps在注册后,有个每日签到的功能,签到后有几率送wps的专属金币[稻米],为了免费获得,又不想每天都是人工去执行签到动作,所以用selenium写了个小脚本,准备用数据驱动框架来完成这个事情,数据驱 ...
- Vue+Vuex实现自动登录 升级版
Vue+Vuex实现自动登录 升级版 之前实现的版本在这里:Vue+Vuex实现自动登录 在之前实现的版本中,如果你进行测试,可以看到在浏览器的local Storage中,确实里面有了我 ...
- python3+任务计划实现的人人影视网站自动签到
python3+任务计划实现的人人影视网站自动签到 这是一个自动化程度较高的程序,运行本程序后会从chrome中读取cookies用于登录人人影视签到, 并且会自动添加一个windows 任务计划,这 ...
- python写的自动签到脚本。
等以后有时间补上. 附上代码: #! /usr/bin/env python # coding:utf-8 #-----------------------------------------学号和密 ...
- 带左右箭头切换的自动滚动图片JS特效
效果图 按钮 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...
随机推荐
- lr_get_transaction_duration 函数介绍
lr_get_transaction_duration 用于获取事务所消耗的时间. 实例: Action() { double trans_time; //定义变量 web_url("www ...
- 在 Windows 上进行 Laravel Homestead 安装、配置及测试
软件环境:在 Windows 7 64位 上基于 VirtualBox 5.2.12 + Vagrant 2.1.1 使用 Laravel Homestead. 1.准备 先下载VirtualBox- ...
- poj2253 Frogger(Floyd)
题目链接 http://poj.org/problem?id=2253 题意 给出青蛙A,B和若干石头的坐标,现在青蛙A要跳到青蛙B所在的石头上,求出所有路径中最远那一跳的最小值. 思路 Floyd算 ...
- 【转】django 与 vue 的完美结合 实现前后端的分离开发之后在整合
https://blog.csdn.net/guan__ye/article/details/80451318 最近接到一个任务,就是用django后端,前段用vue,做一个普通的简单系统,我就是 ...
- mysql 笔记(一)
mysql 笔记 预留 mysql> use mysql; mysql> grant all privileges on *.* to root@'%' identified by &q ...
- 关于 Unity 的一些小细节,不注意可能会被“坑”一些时间。
关于 Unity 的一些小细节,不注意可能会被"坑"一些时间. 最近因为一些"小"问题,总是需要找很久的原因,总结一下 UnityEngine.Input 在使 ...
- Spring boot的hot swapping
前言 嘛,都是看官方文档的,就先贴上文档地址: using-boot-hot-swapping 使用 使用hot swapping只需要把devtools的jar包添加到你的classpath里. 在 ...
- Linux-数据库1
数据库介绍 数据库(database,DB)是指长期存储在计算机内的,有组织,可共享的数据的集合.数据库中的数据按一定的数学模型组织.描述和存储,具有较小的冗余,较高的数据独立性和易扩展性,并可为各种 ...
- redux 初步理解
派发一个 action 给 reducer, reducer 生成了一个新的 state; redux 通过 Store 来保存数据, store.getState 获得数据, 而要更新 state, ...
- cocos2d-android 使用 cocos2d 绘图
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha cocos2d-android-1 https://github.com/ZhouWei ...