java抓取12306信息實(shí)現(xiàn)火車余票查詢示例
最近在弄一個(gè)微信的公眾帳號(hào),涉及到火車票查詢,之前用的網(wǎng)上找到的一個(gè)接口,但只能查到火車時(shí)刻表,12306又沒有提供專門的查票的接口。今天突然想起自己直接去12306上查詢,抓取查詢返回的數(shù)據(jù)包,這樣就可以得到火車票的信息。這里就隨筆記一下獲取12306余票的過程。
首先,我用firefox瀏覽器上12306查詢余票。打開firefox的Web控制臺(tái),選上網(wǎng)絡(luò)中的“記錄請(qǐng)求和響應(yīng)主體”
然后輸入地址日期信息之后點(diǎn)擊網(wǎng)頁上的查詢按鈕,就能在Web控制臺(tái)下看到網(wǎng)頁請(qǐng)求的地址了:
就是圖片中的第二條,即當(dāng)你點(diǎn)擊查詢按鈕時(shí),處理該事件的實(shí)際地址。點(diǎn)開它可以看到
請(qǐng)求網(wǎng)址,請(qǐng)求頭,響應(yīng)頭和響應(yīng)主體這些東西,響應(yīng)主體里就是我們需要的火車票信息。
有了這個(gè)請(qǐng)求網(wǎng)址了就可以到實(shí)際代碼中進(jìn)行操作了??梢园l(fā)現(xiàn)網(wǎng)址的格式是
前面是處理請(qǐng)求的地址,后面接的參數(shù)purpose_codes是指成人票(AADULT),學(xué)生票(自己去試試吧),queryDate就是日期,from_station和to_station顧名思義就是出發(fā)站和到達(dá)站了。這里北京和武漢分別表示為BJP和WHN。
到j(luò)ava代碼里就可以直接寫https請(qǐng)求來獲取火車票信息數(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()是自己寫的將中文的站名轉(zhuǎn)換為字母組合,下面那幾行是關(guān)于https請(qǐng)求的。網(wǎng)址就是剛才獲取到的網(wǎng)址。這段代碼執(zhí)行后得到的輸出內(nèi)容如下:
很容易看出來這些數(shù)據(jù)是一條條的json數(shù)據(jù)(我進(jìn)行了簡(jiǎn)單的處理,讓他一條條打印出來)。
既然是json數(shù)據(jù)就好辦了。取出一條數(shù)據(jù)來進(jìn)行分析就可以分析出來key值代表的意思。我只分析了幾個(gè)我需要的key值
然后就直接寫一個(gè)Train類來儲(chǔ)存火車票的信息,便于之后顯示用了。
public class NewTrain {
private String to_station_name; //到達(dá)地
private String station_train_code; //火車編號(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; // 無座數(shù)量
}
接下來的工作就很簡(jiǎn)單了,將json數(shù)據(jù)放入Train類對(duì)象中。
好了,基本工作完成了,接下來的工作就是將功能整合到項(xiàng)目里去了。
這其中用到的中文站名跟字母組合的一個(gè)txt文件(讀txt獲取中文站名對(duì)應(yīng)的字母的組合,有一些可能不全
- java實(shí)現(xiàn)商品信息管理系統(tǒng)
- Java用list儲(chǔ)存,遍歷,查詢指定信息過程詳解
- Java Web開發(fā)之信息查詢方式總結(jié)
- java操作mongodb基礎(chǔ)(查詢 排序 輸出list)
- 在Java的Hibernate框架中對(duì)數(shù)據(jù)庫數(shù)據(jù)進(jìn)行查詢操作
- 使用Java對(duì)數(shù)據(jù)庫進(jìn)行基本的查詢和更新操作
- java操作mysql入門代碼實(shí)例(含插入、更新和查詢)
- java使用淘寶API讀寫json實(shí)現(xiàn)手機(jī)歸屬地查詢功能代碼
- java 中mongodb的各種操作查詢的實(shí)例詳解
- JAVA基于數(shù)組實(shí)現(xiàn)的商品信息查詢功能示例
相關(guān)文章
SpringBoot @Validated注解實(shí)現(xiàn)參數(shù)分組校驗(yàn)的方法實(shí)例
這篇文章主要給大家介紹了關(guān)于SpringBoot @Validated注解實(shí)現(xiàn)參數(shù)分組校驗(yàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(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ì)象之間的屬性賦值,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05SpringData @Query和@Modifying注解原理解析
這篇文章主要介紹了SpringData @Query和@Modifying注解原理解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08