12306中/otn/HttpZF/logdevice?algID 与 /otn/HttpZF/GetJS 的关系

前言:又快要到国庆了,又绕不过抢票,索性自己研究下,之前也有研究,不过遇到了点问题,今天有时间就又研究了下12306接口。

 

个人猜测, /otn/HttpZF/GetJS是从服务端获取js,然后本地执行,然后生成  /otn/HttpZF/logdevice  及后面的url,并通过该请求获取这两个cookie,这几个cookie是全局的(每个请求的域名都会发送)

 

首先来看这个url

https://kyfw.12306.cn/otn/HttpZF/logdevice?algID=2stcaJcUyY&hashCode=avBnjD166jiYr2gj8mypTbfvAkCdHubgLOGtA-Rafqc&FMQw=1&q4f3=zh-CN&VySQ=FGE_hPihSScDBogj7DfPQ6ooHWG53-VA&VPIf=1&custID=133&VEek=unknown&dzuS=0&yD16=0&EOQP=e1d07183b0bcf39b1e2666fcf1a42815&jp76=4e29ab686b123b70e7c6482485599219&hAqN=MacIntel&platform=WEB&ks0Q=1f99cc42a96f6a3c6934c6efe8c77219&TeRS=736x1280&tOHY=24xx800x1280&Fvje=i1l1o1s1&q5aJ=-8&wNLf=99115dfb07133750ba677d055874de87&0aew=Mozilla/5.0%20(Macintosh;%20Intel%20Mac%20OS%20X%2010_11_6)%20AppleWebKit/537.36%20(KHTML,%20like%20Gecko)%20Chrome/75.0.3770.142%20Safari/537.36&E3gR=4df1c16d4f8a086acba914a9d2592036&timestamp=1563954631896

返回

callbackFunction('{"exp":"1564214075477","dfp":"iF4ApENCyh6Kdw1URaT70G7H_7ZPcRcXGYWMrWNm7OY3kxkh794ENoW8YzUTjIgiP1MpEXsij9Gp7NVKEj9TOlfX-K4yka5ngroOU9Kbk_sqnQabcS-aXwb6c6uqNH4AbcWdfn42PNoIh-j7vMTF-4elzPHhex4H"}')

exp即  RAIL_EXPIRATION

dfp即  RAIL_DEVICEID 

 

怎么验证呢?

将  algID 在 /otn/HttpZF/GetJS 返回的js中查找,将会看到

Ya.getJSON("https://kyfw.12306.cn/otn/HttpZF/logdevice" + ("?algID\x3d2stcaJcUyY\x26hashCode\x3d" + e + a), null, function(a) {
 

在继续在 /otn/HttpZF/GetJS返回的js中查找getJSON,就会看到

 

var Ya = {
        removeElem: function(a) {
            var b = a.parentNode;
            if (b)
                try {
                    b.removeChild(a)
                } catch (c) {}
        },
        rand: function() {
            return Math.random().toString().substr(2)
        },
        now: function() {
            return (new Date).getTime()
        },
        getJSON: function(a, b, c) {
            b = u.createElement("script");
            b.type = "text/javascript";
            b.src = a;
            b.id = "id_callbackFunction";
            r.callbackFunction = function(a) {
                r.callbackFunction = void 0;
                var b = u.getElementById("id_callbackFunction");
                b && Ya.removeElem(b);
                c(a)
            }
            ;
            (a = u.getElementsByTagName("head")) && a[0] && a[0].appendChild(b)
        },

这样就明白了,12306是通过创建 <script src="https://kyfw.12306.cn/otn/HttpZF/logdevice?algID=*************">这个标签来发送这个url的,然后再将返回的数据,用js写入cookie。这样就明白了流程,

 

下期再研究下  /otn/HttpZF/logdevice这个后面的众多参数生成规则,这样就可以自己写登陆了。

 

推荐我现在经常用的 一个  抢票软件 ,心到抢票 ,方便实惠,欢迎大家使用。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值