解决360抢票王刷票0.1秒停顿问题,思考抢票软件和IT行业

一 问题描述

一直用360浏览器带的扩展应用:360抢票王,用了很多年了,挺好使(在这里谢谢360抢票王技术团队的同仁们),主要是信任在本地自己电脑上刷票,虽然自己电脑配置和网络一般,但还是很有期望的,我几乎每次都能刷到票,不像那种嗷嗷着在云端刷票,在云端刷票,老感觉,看不见摸不着,不知道给刷没刷,或许是程序员的职业病吧。

不过最近更新了360抢票王,用了七代经典版,一天吃完饭,打开看看刷票状态,突然看“您关注的座席和车次没有余票,0.1秒后为您尝试第 13 次刷票!”,一直卡顿在这,不动了,我去半天就给刷了13次,后来换了台电脑也会时不时出现这种情况?

这里先给火急火燎的小伙伴们解决方案吧,最后再说说我分析的原因:

二 先解决问题,在吹牛皮(解决方案)

第一步,设置好正常的刷票状态,一定要是开始刷票状态。

解决360抢票王刷票0.1秒停顿问题,思考抢票软件和IT行业

 

第二步 打开开发人员工具,一般按F12功能键。

如果F12功能键不好使,参考下图,打开开发人员工具:

解决360抢票王刷票0.1秒停顿问题,思考抢票软件和IT行业

 

第三步,执行小编写的扩展js代码,模拟定时重新启动刷票代码。

解决360抢票王刷票0.1秒停顿问题,思考抢票软件和IT行业

 

具体代码:

window.RefreshCount=0;

window.SomeCount=0;

var outHandler=null;

function CheckRefreshStatus(){

try{

var count= parseInt($("#refresh_count").html());

if(window.RefreshCount==count){

window.SomeCount+=1;

}

window.RefreshCount=count;

if(window.SomeCount==2){

ReSetRefresh();

}

}

catch(err){}

}

function ReSetRefresh(){

window.SomeCount=0;

$("#btn_refresh").click();

if(outHandler!=null){

clearTimeout(outHandler);

}

outHandler=setTimeout('$("#btn_refresh").click();',1000);

}

var tempHandler= setInterval(CheckRefreshStatus,6000);

代码复制到,上图的位置,按回车键。

三 细分说一下原因

1.刷票原理

大概说一下我分析的360抢票王的抢票原理,只分析刷票部分,其实就是前端js发http请求,查询12306的接口,当然这个过程中要解决跨越等问题,这个不多说,没有深入分析,看下图:

解决360抢票王刷票0.1秒停顿问题,思考抢票软件和IT行业

 

看看具体的请求地址:

解决360抢票王刷票0.1秒停顿问题,思考抢票软件和IT行业

 

从上面可以看到,其实就是每隔5秒,会请求一次上面的车票查询地址。

2.发现问题

解决360抢票王刷票0.1秒停顿问题,思考抢票软件和IT行业

 

之所以出现“您关注的座席和车次没有余票,0.1秒后为您尝试第 13 次刷票!”,估计就是刷票的时候js报错没有很好的异常处理机制,导致后续的代码不在运行。写过js的都知道,js报错之后,不捕获异常,就会导致js运行停止。

3.知道了可能的问题,解决问题

方案1 :每次手动,点击停止刷票,在点击高速刷票,让它重新刷票。

解决360抢票王刷票0.1秒停顿问题,思考抢票软件和IT行业

 

因为出现0.1秒停顿的概率挺高的,这种不现实。pass

方案2 :分析360抢票王的js代码部分,找到发请求的地方,处理一下。

分析了一下没有找到,赖的深入分析,好不容易一个周末,在这分析了半天,万一与浏览器内部有交互就不好弄了。pass

方案3 写一段js,让其执行方案1的操作,分析实现思路:

通过下图,发现高速刷票按钮的元素标签id是:btn_refresh

解决360抢票王刷票0.1秒停顿问题,思考抢票软件和IT行业

 

解决360抢票王刷票0.1秒停顿问题,思考抢票软件和IT行业

 

分析刷票次数,显示刷票次数的标签的id是:refresh_count

解决360抢票王刷票0.1秒停顿问题,思考抢票软件和IT行业

 

解决360抢票王刷票0.1秒停顿问题,思考抢票软件和IT行业

 

思路是:因为抢票王是5秒刷一次,这个时候我设置6秒检测一下refresh_count标签里面的,是否变化(与全局变量a比较),然后赋值全局变量a,如果没有变化,则全局变量b自增1,判断全局变量b如果为2,执行点击停止刷票按钮代码:$("#btn_refresh").click(); 全局变量b归0,这个时候按钮变成高速刷票状态,1秒之后,在执行点击高速刷票按钮代码:$("#btn_refresh").click(); 必须有个时间间隔后。

注:经分析,抢票王引用了jquery,所以可以用jquery语法。

抢票软件

技术手段分为:

1.模拟人点击的

2.调用12306官方提供的api的。

运行方式:

1.本地的,就是在自己电脑上运行的

2.云端,就是在抢票软件提供方,提供的高速服务器上,一般都收费。免费的,你想吧。

 

我个人觉得抢票软件最有难度的,还是验证码识别部分,猜测:估计是,事先搜集所有的验证码图片里面可能出现的小图存储起来,然后比对分析,当然可能模糊或模式识别。

我之前也写过验证码识别,只不过是识别纯数字和字母的,这个就简单多了,先灰度化处理,也就是二值化处理,切割,去燥,模式库比对等等,好多年了,都忘了,呵呵。

IT行业思考

要解决这种全民抢票的现象,我觉得一个出路:平台+个人,大家自由组合,不限地点和时间,不在是公司+个人了,随着5G网络的高速发展,全息投影等技术的成熟,都呀在家工作,谁还漂在外,经常买票。

在这里愿大家,都顺顺利利,买上票,回家过大年,提前祝大家新年快乐,万事如意。

 

欢迎大家在今日头条内搜索“全民学编程”  关注我

原文:https://www.toutiao.com/a6645900009734668803/

转载请备注出处:https://www.toutiao.com/a6645900009734668803/

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值