前言:又快要到国庆了,又绕不过抢票,索性自己研究下,之前也有研究,不过遇到了点问题,今天有时间就又研究了下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这个后面的众多参数生成规则,这样就可以自己写登陆了。

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

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

  1. 爬取12306中全国的列车时刻表和车站信息

    我使用的时间是2023年7月22日,后续12306有可能继续更新,所以这里只是一个分享 首先打开12306的官网 然后随便找一个路线进行查询 f12打开开发者菜单后找到station_name.js? ...

  2. legend---十二、js中的js语句和函数和ready函数的关系是什么

    legend---十二.js中的js语句和函数和ready函数的关系是什么 一.总结 一句话总结: 函数和全局变量不必放到ready函数中 语句(调用函数和全局变量)的必须放到ready函数中 1.在 ...

  3. # JavaScript中的执行上下文和队列(栈)的关系?

    原文:What is the Execution Context & Stack in JavaScript? git地址:JavaScript中的执行上下文和队列(栈)的关系? 导读:以前总 ...

  4. nginx 中location和root,你确定真的明白他们关系?

    最近公司开发新项目,web server使用nginx,趁周末小小的研究了一下,一不小心踩了个坑吧,一直404 not found!!!!!当时卡在location和root中,但是网上却比较少聊这方 ...

  5. Java中常见RuntimeException与其他异常表及Exception逻辑关系详解

    Java中常见RuntimeException与其他异常表及Exception逻辑关系详解 前言 常见`RuntimeException` 其他错误类型 `Error`类 `Exception`类 E ...

  6. flex中的架构,(举例UIComponent类的继承关系)

    flex中的架构,(举例UIComponent类的继承关系) UIComponent > FlexSprite> Sprite >DisplayObjectContainer> ...

  7. oracle中同个字段匹配多个like(or关系)实例解决方案

    oracle中同个字段匹配多个like(or关系)实例解决方案 这样一段sql,要查询title这个字段里包含(150,160,85,1x,23,-,98)的数据 SELECTtitleFROMtes ...

  8. 项目规划中的Epic、Feature、Story和Task的关系

    项目规划中的Epic.Feature.Story和Task的关系 Feature Minimal Marketable Feature (MMF) Epic Story User Story User ...

  9. Unity物理系统中碰撞体、刚体、isKinematic、isTrigger的关系(附动画演示)

    Unity物理系统中碰撞体.刚体.isKinematic.isTrigger的关系 写在前面 产生碰撞的条件 产生触发的条件 实验一:蓝块(碰撞体).红块(碰撞体) 实验二:蓝块(碰撞体).红块(碰撞 ...

最新文章

  1. linux oracle修改编码utf8
  2. Java 泛型 T,E,K,V,?,傻傻分不清?
  3. 机器学习算法源码全解析(一)-带你深入理解随机森林(RandomForest)原理及如何防止 Dropout
  4. 单链表之头插法的理解!
  5. L1-005 考试座位号
  6. 华为笔记本matebook13_华为MateBook 13_HUAWEI MateBook 13(i5 8265U/8GB/256GB/独显)_笔记本导购-中关村在线...
  7. win 2008 server 更改远程桌面端口的方法
  8. Visual basic 6读写ini文件
  9. 【openMV】openMV4之sensor模块
  10. Github 源码阅读神器:Octotree
  11. 【论文研读】【目标检测】Revisiting Open World Object Detection
  12. Leetcode-845. 数组中的最长山脉(最详细解法)
  13. 首发的400G园区核心交换机,开启园区超宽时代
  14. matlab 图片倒影_matlab-画个拱桥和倒影?
  15. 鸿蒙之初彩蛋攻略,鸿蒙圣女 热血精灵派鸿蒙灵帝解析
  16. 视频基本术语介绍 码流、帧率、分辨率、I帧、带宽
  17. shell foreach
  18. office2010 word 关闭很慢
  19. 【转载】一些软件设计原则
  20. SANGFOR SCSA——信息安全概述

热门文章

  1. 非常简洁的vsPlayAudio在线音乐播放器插件
  2. VS2017操做sql server数据库
  3. JS-修改图片颜色值
  4. 全国青少年编程等级考试python一级真题2021年3月(含题库答题软件账号)
  5. iOS基础——UI控件之UIAlertController、UINavigationController、Segue、SVProgressHUD
  6. 中关村科金李超:多元融合成为音视频技术发展新风向
  7. 【爬虫进阶】常见的反爬手段和解决方法(建议收藏)
  8. 基于springboot实现疫情上报系统
  9. Centos7 升级 glibc 2.25
  10. 国王的金币for循环