分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 前端开发

js刷票脚本

发布时间:2023-09-06 01:37责任编辑:熊小新关键词:js

现在脚本的功能有:
1、防止自动刷票崩溃(挂掉后自动重新刷票)
2、自定义查询时间区间
3、自定义自动刷新时间间隔
4、突破5车次限制
5、可根据时间段、车类型刷所有满足的车次
废话不多说,直接上代码吧:

//记录等待时间 ?var waittime=0; ???//统计等待时间 ?function waitforRestart(){ ?????if(!$("#autoSubmit").prop("checked"))return ; ?????if($("#query_ticket").text()=="停止查询"){ ?????????waittime++; ?????} ?????if(waittime>10){ ?????????$("#query_ticket").click(); ?????????setTimeout(function(){ ?????????????waittime=0; ?????????????if($("#query_ticket").text()=="查询") { ?????????????????$("#query_ticket").click(); ?????????????} ?????????},1000); ?????} ?} ???//注册回调方法 ?function callback(fun1,fun2){ ???fun1(); ???fun2(); ?} ???//添加乘车人 ?function addBuyer(name){ ???callback($.showSelectBuyer,function(){ ?????$("#buyer-list li[p_value^="+name+"]").click(); ?????$.closeSelectBuyer(); ???}); ?} ???//突破限制,添加车次 ?function addTrain(trainCode){ ???$("#prior_train").append(‘<span name="prior_train-span" class="sel-box w80">‘+trainCode+‘<a class="close" href="javascript:" onclick="$.removeSel(this,"‘+trainCode+‘",4)"></a></span>‘); ?} ???//添加优先席别 ?function addSeat(seat){ ???callback($.showSelectSeat, function(){ ?????$("#seat-list li[name^="+seat+"]").click(); ?????$.closeSelectSeat(); ???}); ?} ???//自定义查询区间 ?function addTimes(startTime,endTime){ ?????$("#cc_start_time").append(‘<option value="‘+startTime.replace(":","")+endTime.replace(":","")+‘">‘+startTime+‘--‘+endTime+‘</option>‘); ?????$("#cc_start_time option:last").selected(); ?} ???//根据时间段、车次类型查询所有满足的车次。 ?function queryByTimeAndTrainType(){ ???callback($.showYxTrain, function(){ ?????var yxTrainTimer = setInterval(function(){ ???????if($("#filterTic").length>0){ ?????????$("#filterTic").prop("checked",true); ?????????$("#yxtrain_close").click(); ??????????clearInterval(yxTrainTimer); ???????} ?????},10); ???}); ?} ?

以上是提供了修改配置的方法,以下则根据需求自行配置,我们可以选定车次进行刷票,也可以根据时间段+车次类型刷该时间段内的某类车次。分开来说:
1. 根据车次进行刷票
具体操作:
打开12306网站
选定好车次方向和发车日期
筛选出要刷新的车次、乘车人、席做等,替换下面的内容

//========================================== ?// ?以下则根据需求自行配置: ?// ?????乘车人、车次、席别 ?// ?????仅显示要刷的车次、查询区间、刷新时间 ?//========================================== ???//选择乘车人 ?addBuyer("张三"); ?addBuyer("‘李四(成人)‘"); ?addBuyer("‘王五(学生)‘"); ???//手动添加车次,按优先顺序添加(轻松突破5车次限制) ?addTrain("G100"); ?addTrain("G101"); ?addTrain("G102"); ?addTrain("G103"); ?addTrain("G104"); ?addTrain("G105"); ?addTrain("G106"); ?addTrain("G107"); ???//添加优先席别,按优先顺序添加 ?addSeat("二等座"); ?addSeat("一等座"); ???//自动刷新时间1s ?autoSearchTime=1000; ???//收起订票助手 ?$(".up").click(); ???//启动检测防挂 ?var timer = setInterval(waitforRestart,autoSearchTime); ???//开始刷票 ?if($("#query_ticket").text()=="查询"){ ???var timer2 = setInterval(function(){ ?????if($("#auto_query").prop("checked") && $("#autoSubmit").prop("checked") && $("#filterTic").prop("checked")){ ???????$("#query_ticket").click(); ???????clearInterval(timer2); ?????} ???},10); ?} ?

2. 刷新某时间段内的特定车次类型的票,如刷新09:30-12:15之间所有高铁+动车票
具体操作:
打开12306
选好车次方向和发车日期
确定时间段、车次类型、席坐,然后替换下面的内容

//========================================== ?// ?以下则根据需求自行配置: ?// ?????乘车人、车次、席别 ?// ?????仅显示要刷的车次、查询区间、刷新时间 ?//========================================== ???//选择乘车人 ?addBuyer("张三"); ?addBuyer("‘李四(成人)‘"); ?addBuyer("‘王五(学生)‘"); ???//添加优先席别,按优先顺序添加 ?addSeat("二等座"); ???//手动设置查询区间 ?addTimes("09:30","12:15"); ???//仅显示高铁+动车 ?$(".check[value=‘G‘]").prop("checked",true); ?$(".check[value=‘D‘]").prop("checked",true); ???//仅显示时间段内的车次、仅显示有票的车次,二选一 ?//注意,如果选择了该项,则勾选的车次则无效了。 ?queryByTimeAndTrainType(); ???//自动刷新时间1s ?autoSearchTime=1000; ???//收起订票助手 ?$(".up").click(); ???//启动检测防挂 ?var timer = setInterval(waitforRestart,autoSearchTime); ???//开始刷票 ?if($("#query_ticket").text()=="查询"){ ???var timer2 = setInterval(function(){ ?????if($("#auto_query").prop("checked") && $("#autoSubmit").prop("checked") && $("#filterTic").prop("checked")){ ???????$("#query_ticket").click(); ???????clearInterval(timer2); ?????} ???},10); ?} ?

将以上修改好的内容贴到浏览器控制台上(F12,console选项卡)按回车执行。就可以自动开始刷票了。如果刷新请求timeout了,会由waittime记录超时等待时间,>10时则会自动取消刷新,1秒后重新开始自动刷票。

js刷票脚本

原文地址:https://www.cnblogs.com/kwm672225801/p/8317442.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved