12306搶票軟件相關接口以及數據格式

 

        直接步入正題吧,在這主要想說下現在的12306各個功能的接口以及數據格式。主要分爲登錄,獲取聯繫人,查票,預定,查詢未完成訂單五個模塊,至於其他的一些接口不重要,可以直接忽略,比如檢測驗證碼是否正確,請求車票剩餘個數等等,本文併爲寫出來,有需求的可以自行研究。
       一、登錄
             登錄主要是獲取session,保持與服務器端通信。登錄主要有兩個步驟
             第一 獲取登錄驗證碼
                     方法:GET
                     接口:https://kyfw.12306.cn/otn/passcodeNew/getPassCodeNew.do?module=login&rand=sjrand&
                     參數:照抄,一樣的
                     返回:二進制圖片流
             第二 登錄
                    方法:POST
                    接口:https://kyfw.12306.cn/otn/login/loginAysnSuggest
                    參數:1、loginUserDTO.user_name 用戶名
                               2、randCode 驗證碼
                               3、userDTO.password 密碼
                     返回:json字符串,可判斷是否登錄成功
        二、獲取聯繫人
                    方法:GET
                    接口:https://kyfw.12306.cn/otn/passengers/init
                    參數:無
                    返回:html文件,裏面能夠找到一個變量,是json格式的,能夠解析成user對象
        三、查票
                    方法:GET
                    接口:https://kyfw.12306.cn/otn/leftTicket/query?
                    參數:leftTicketDTO.train_date:查票日期
                               leftTicketDTO.from_station:起始站(字母代號)
                               leftTicketDTO.to_station:目的站(字母代號)
                               purpose_codes:ADULT
                    返回:返回json格式,直接解析
         四、預定
                   預定分6個步驟,一一進行,相互關聯
                   第一:預提交
                            方法:POST
                            接口:https://kyfw.12306.cn/otn/leftTicket/submitOrderRequest
                            參數:secretStr:從查票中獲得(每個車次對應一個,並且每次都不一樣,需要實時解析)
                                      train_date:訂票日期
                                     back_train_date:返程日期
                                      tour_flag: dc
                                      purpose_codes:ADULT
                                      query_from_station_name:出發站
                                      query_to_station_name:目的站
                                      undefined:空字符串
                           返回:返回json格式,判斷是否提交成功
                    第二:獲取相應參數
                            方法:POST
                            接口:https://kyfw.12306.cn/otn/confirmPassenger/initDc
                             參數:
                              _json_att:空字符串
                             返回:html文件,在前幾行解析globalRepeatSubmitToken 下面有用,以及從下面獲取ticketInfoForPassengerForm變量的值,是個json格式,從中獲取purpose_codes,key_check_isChange,leftTicketStr,train_locatio{過濾}n爲下面提交做準備
                    第三:獲取提交驗證碼
                              方法:GET
                             接口:https://kyfw.12306.cn/otn/passcodeNew/getPassCodeNew.do?module=passenger&rand=randp&
                             參數:
                                      無
                             返回:和登錄驗證碼一樣,返回圖片二進制流
                     第四:檢測是否可以確認提交
                             方法:POST
                              接口:https://kyfw.12306.cn/otn/confirmPassenger/checkOrderInfo
                              參數:
                                       cancel_flag:2
                                       bed_level_order_num:000000000000000000000000000000
                                       passengerTicketStr:座位類型,0,車票類型,姓名,身份正號,電話,N(多個的話,以逗號分隔)
                                       oldPassengerStr:姓名,證件類別,證件號碼,用戶類型
                                       randCode:預定驗證碼
                                       tour_flag:dc
                                       _json_att:空字符串
                                       REPEAT_SUBMIT_TOKEN:從上一步獲取
                              返回:json格式,判斷是否可以提交
                    第五:確認提交
                                方法:POST
                                接口:https://kyfw.12306.cn/otn/confirmPassenger/confirmSingleForQueue
                                參數:
    
                                       passengerTicketStr:座位類型,0,車票類型,姓名,身份正號,電話,N(多個的話,以逗號分隔)
                                       oldPassengerStr:姓名,證件類別,證件號碼,用戶類型
                                       randCode:預定驗證碼
                                       purpose_codes:第3步獲取
                                       key_check_isChange:同上
                                       leftTicketStr;同上
                                       train_locatio{過濾}n;同上
                                       REPEAT_SUBMIT_TOKEN:同上
                                       _json_att:空字符串    
                               返回:json格式,判斷是否提交成功,並返回等待時間,每隔一定時間段調用第六步返回處理結果
                     第六:輪詢獲取提交結果
                               方法:GET
                               接口:https://kyfw.12306.cn/otn/confirmPassenger/queryOrderWaitTime?
                               參數:
    
                                       random:隨機數字
                                       tourFlag:dc    
                                       REPEAT_SUBMIT_TOKEN:有第三部獲取
                                       _json_att:空字符串    
                               返回:json格式,返回等待時間,如果waitTime小於0,則獲取訂單信息orderId,如果大於0,則繼續輪詢
          五、查詢未完成訂單
                 方法:POST
                 接口:https://kyfw.12306.cn/otn/queryOrder/queryMyOrderNoComplete
                 參數:
                _json_att:空字符串    
                返回:json格式,包含訂單信息,直接解析

           說到這,5個功能基本就介紹了,但現在貼出來只是爲了學習使用,不會惡意攻擊,況且,12306網站接口更改很頻繁,現在貼出來的接口說不定明天就 被改了,所以重要的其實還是學會怎麼抓取相關接口和數據,以及從數據中進行分析獲取相應的參數,相應的結果。在這裏我主要用了firebug,chrom瀏覽器自帶 的網絡分析工具,以及fiddler和wireshark工具,相關工具使用說明,就自己在網上找吧。
            最後在吐槽一下吧,12306網站用到了cdn靜態緩存技術,會導致在不同的區域,帶寬,負載下根據負載均衡選擇相應的服務器,也就是說全國各地有很多的12306服務器 每個用戶訪問的可能服務器是不樣的,但只是靜態頁面和js、css和圖片等,但各個服務器直接會保持session共享的,也就是在其中一臺服務器登陸的話,在別的服務器 上面也相當於已經登陸了。所以最好能夠動態選擇服務器,使緩存時間最新,壓力最小,數據更實時很重要。在我的實現中就是沒查詢一次,就會換一次服務器ip。至於相關 技術我以後會揭曉。但本文的內容對於學習來說已經夠了。查詢具體ip在http://tool.chinaz.com/dns  裏面能夠看到。

from :https://www.cnblogs.com/dare/p/8286781.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章