java抓取12306信息實(shí)現(xiàn)火車(chē)余票查詢(xún)示例
最近在弄一個(gè)微信的公眾帳號(hào),涉及到火車(chē)票查詢(xún),之前用的網(wǎng)上找到的一個(gè)接口,但只能查到火車(chē)時(shí)刻表,12306又沒(méi)有提供專(zhuān)門(mén)的查票的接口。今天突然想起自己直接去12306上查詢(xún),抓取查詢(xún)返回的數(shù)據(jù)包,這樣就可以得到火車(chē)票的信息。這里就隨筆記一下獲取12306余票的過(guò)程。
首先,我用firefox瀏覽器上12306查詢(xún)余票。打開(kāi)firefox的Web控制臺(tái),選上網(wǎng)絡(luò)中的“記錄請(qǐng)求和響應(yīng)主體”
然后輸入地址日期信息之后點(diǎn)擊網(wǎng)頁(yè)上的查詢(xún)按鈕,就能在Web控制臺(tái)下看到網(wǎng)頁(yè)請(qǐng)求的地址了:
就是圖片中的第二條,即當(dāng)你點(diǎn)擊查詢(xún)按鈕時(shí),處理該事件的實(shí)際地址。點(diǎn)開(kāi)它可以看到
請(qǐng)求網(wǎng)址,請(qǐng)求頭,響應(yīng)頭和響應(yīng)主體這些東西,響應(yīng)主體里就是我們需要的火車(chē)票信息。
有了這個(gè)請(qǐng)求網(wǎng)址了就可以到實(shí)際代碼中進(jìn)行操作了。可以發(fā)現(xiàn)網(wǎng)址的格式是
前面是處理請(qǐng)求的地址,后面接的參數(shù)purpose_codes是指成人票(AADULT),學(xué)生票(自己去試試吧),queryDate就是日期,from_station和to_station顧名思義就是出發(fā)站和到達(dá)站了。這里北京和武漢分別表示為BJP和WHN。
到j(luò)ava代碼里就可以直接寫(xiě)https請(qǐng)求來(lái)獲取火車(chē)票信息數(shù)據(jù)包了
public static List<NewTrain> getmsg(String startCity,String endCity,int isAdult) throws Exception{
List<NewTrain> trains = new ArrayList<NewTrain>();
String sstartCity = CityCode.format(startCity);
String sendCity = CityCode.format(endCity);
TrustManager[] tm = {new MyX509TrustManager()};
SSLContext sslContext = SSLContext.getInstance("SSL", "SunJSSE");
sslContext.init(null, tm, new java.security.SecureRandom());
// 從上述SSLContext對(duì)象中得到SSLSocketFactory對(duì)象
SSLSocketFactory ssf = sslContext.getSocketFactory();
String type = "ADULT";
if(isAdult == 1){
type = "0X00";
}
String urlStr = "https://kyfw.12306.cn/otn/lcxxcx/query?purpose_codes="+type+"&queryDate=2014-04-27&from_station="+sstartCity+"&to_station="+sendCity;
URL url = new URL(urlStr);
HttpsURLConnection con = (HttpsURLConnection) url.openConnection();
con.setSSLSocketFactory(ssf);
InputStreamReader in = new InputStreamReader(con.getInputStream(),"utf-8");
BufferedReader bfreader = new BufferedReader(in);
StringBuffer sb = new StringBuffer();
String line = "";
while ((line = bfreader.readLine()) != null) {
sb.append(line);
}
System.out.println(sb.toString());
}
這段代碼的cityCode.format()是自己寫(xiě)的將中文的站名轉(zhuǎn)換為字母組合,下面那幾行是關(guān)于https請(qǐng)求的。網(wǎng)址就是剛才獲取到的網(wǎng)址。這段代碼執(zhí)行后得到的輸出內(nèi)容如下:
很容易看出來(lái)這些數(shù)據(jù)是一條條的json數(shù)據(jù)(我進(jìn)行了簡(jiǎn)單的處理,讓他一條條打印出來(lái))。
既然是json數(shù)據(jù)就好辦了。取出一條數(shù)據(jù)來(lái)進(jìn)行分析就可以分析出來(lái)key值代表的意思。我只分析了幾個(gè)我需要的key值
然后就直接寫(xiě)一個(gè)Train類(lèi)來(lái)儲(chǔ)存火車(chē)票的信息,便于之后顯示用了。
public class NewTrain {
private String to_station_name; //到達(dá)地
private String station_train_code; //火車(chē)編號(hào)
private String from_station_name; //出發(fā)地
private String start_time; //出發(fā)時(shí)間
private String arrive_time; // 到達(dá)時(shí)間
private String lishi; // 需要時(shí)間
private String zy_num; // 一等座數(shù)量
private String ze_num; // 二等座數(shù)量
private String swz_num; // 商務(wù)座數(shù)量
private String gr_num; // 高級(jí)軟臥數(shù)量
private String rw_num; // 軟臥數(shù)量
private String rz_num; // 軟座數(shù)量
private String yw_num; // 硬臥數(shù)量
private String yz_num; // 硬座數(shù)量
private String tz_num; // 特等座數(shù)量
private String wz_num; // 無(wú)座數(shù)量
}
接下來(lái)的工作就很簡(jiǎn)單了,將json數(shù)據(jù)放入Train類(lèi)對(duì)象中。
好了,基本工作完成了,接下來(lái)的工作就是將功能整合到項(xiàng)目里去了。
這其中用到的中文站名跟字母組合的一個(gè)txt文件(讀txt獲取中文站名對(duì)應(yīng)的字母的組合,有一些可能不全
- java實(shí)現(xiàn)商品信息管理系統(tǒng)
- Java用list儲(chǔ)存,遍歷,查詢(xún)指定信息過(guò)程詳解
- Java Web開(kāi)發(fā)之信息查詢(xún)方式總結(jié)
- java操作mongodb基礎(chǔ)(查詢(xún) 排序 輸出list)
- 在Java的Hibernate框架中對(duì)數(shù)據(jù)庫(kù)數(shù)據(jù)進(jìn)行查詢(xún)操作
- 使用Java對(duì)數(shù)據(jù)庫(kù)進(jìn)行基本的查詢(xún)和更新操作
- java操作mysql入門(mén)代碼實(shí)例(含插入、更新和查詢(xún))
- java使用淘寶API讀寫(xiě)json實(shí)現(xiàn)手機(jī)歸屬地查詢(xún)功能代碼
- java 中mongodb的各種操作查詢(xún)的實(shí)例詳解
- JAVA基于數(shù)組實(shí)現(xiàn)的商品信息查詢(xún)功能示例
相關(guān)文章
SpringBoot @Validated注解實(shí)現(xiàn)參數(shù)分組校驗(yàn)的方法實(shí)例
這篇文章主要給大家介紹了關(guān)于SpringBoot @Validated注解實(shí)現(xiàn)參數(shù)分組校驗(yàn)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09JAVA中excel導(dǎo)出一對(duì)多合并具體實(shí)現(xiàn)
項(xiàng)目中經(jīng)常會(huì)使用到導(dǎo)出功能,有導(dǎo)出Word,有導(dǎo)出Excel的,下面這篇文章主要給大家介紹了關(guān)于JAVA中excel導(dǎo)出一對(duì)多合并具體實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2023-09-09如何使用BeanUtils.copyProperties進(jìn)行對(duì)象之間的屬性賦值
這篇文章主要介紹了使用BeanUtils.copyProperties進(jìn)行對(duì)象之間的屬性賦值,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05SpringData @Query和@Modifying注解原理解析
這篇文章主要介紹了SpringData @Query和@Modifying注解原理解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08