`
SorosW
  • 浏览: 9934 次
  • 来自: 苏州
文章分类
社区版块
存档分类
最新评论

聚合数据iOS SDK 12306火车票查询订票演示示例

 
阅读更多

1,将聚合数据SDK(JuheApis.framework)添加到你的程序中来,SDK依赖的包包括:



2,在聚合SDK Framework的JHSDKAPIPath.h文件中找到快递查询接口宏,以及字典参数

/* 12306火车票查询订票 */
/**
@brief 2306火车票查询订票--1、车次查询
@param lname string 必填 车次名称,如:G4
@param ldtype string 非必填 返回数据的格式,xml或json,默认json
*/
#define kJHAPIS_LIFE_TRAIN_S @"juhe.apis.train.s" //1、车次查询

/**
@brief 12306火车票查询订票--2、站到站查询
@param start string 必填 出发站
@param end string 必填 终点站
@param traintype string 非必填 列车类型,G-高速动车 K-快速 T-空调特快 D-动车组 Z-直达特快 Q-其他
@param dtype string 非必填 返回数据的格式,xml或json,默认json
*/
#define kJHAPIS_LIFE_TRAIN_S2S @"juhe.apis.train.s2s" //2、站到站查询

/**
@brief 12306火车票查询订票--3、12306实时余票查询
@param dtype string 非必填 返回数据的格式,xml或json,默认json
@param from string 必填 出发站,如:上海虹桥
@param to string 必填 到达站,如:温州南
@param date string 非必填 出发日期,默认今日
@param tt string 非必填 车次类型,默认全部,如:G(高铁)、D(动车)、T(特快)、Z(直达)、K(快速)、Q(其他)
*/
#define kJHAPIS_LIFE_TRAIN_YP @"juhe.apis.train.yp" //3、12306实时余票查询

/**
@brief 12306火车票查询订票--4、12306订票①:查询车次
@param from string 必填 出发站名称:如上海虹桥
@param to string 必填 到达站名称:如温州南
@param date date 非必填 默认当天,格式:2014-07-11
@param tt string 非必填 车次类型,默认全部,如:G(高铁)、D(动车)、T(特快)、Z(直达)、K(快速)、Q(其他)
*/
#define kJHAPIS_LIFE_TRAIN_TICKET_CC @"juhe.apis.train.ticket.cc" //4、12306订票①:查询车次

/**
@brief 12306火车票查询订票--5、12306订票②:提交订单
@param name string 必填 乘客姓名
@param seat string 必填 座位类型:商务座:9,一等座:M,二等座:O,特等座:P,高级软卧:6,软卧:4,硬卧:3,软座:2,硬座:1,无座:0
@param mobile string 必填 乘客手机号码
@param idcard string 必填 乘客身份证号码
@param username string 必填 12306官网账号
@param password string 必填 12306官网密码
@param train_no string 必填 步骤①对应车次返回值
@param station_train_code string 必填 步骤①对应车次返回值
@param from_station_telecode string 必填 步骤①对应车次返回值
@param to_station_telecode string 必填 步骤①对应车次返回值
@param from_station_name string 必填 步骤①对应车次返回值
@param to_station_name string 必填 步骤①对应车次返回值
@param secretStr string 必填 步骤①对应车次返回值
*/
#define kJHAPIS_LIFE_TRAIN_TICKET_ORDER @"juhe.apis.train.ticket.order" //5、12306订票②:提交订单



3,快递查询接口在程序中调用方法(将ViewController.m改为.mm)

#import "ViewController.h"

#import <JuheApis/JuheAPI.h>
#import <JuheApis/JHOpenidSupplier.h>
#import <JuheApis/JHSDKAPIPath.h>

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
[[JHOpenidSupplier shareSupplier] registerJuheAPIByOpenId:@"申请到的OpenId“];

UIButton* beginBtn=[UIButton buttonWithType:UIButtonTypeSystem];
beginBtn.frame=CGRectMake(20, 111, 280, 40);
[beginBtn setTitle:@"开始" forState:UIControlStateNormal];
[beginBtn setTitleColor:[UIColor darkGrayColor] forState:UIControlStateNormal];
[beginBtn addTarget:self action:@selector(doTestAction) forControlEvents:UIControlEventTouchUpInside];
[beginBtn setBackgroundImage:[UIImage imageNamed:@"button5"] forState:UIControlStateNormal];
[self.view addSubview:beginBtn];
}

- (void)doTestAction
{
/* 1、车次查询 */
[self test : kJHAPIS_LIFE_TRAIN_S parameters:@{@"name":@"G4" , @"dtype":@"json" }];


/* 2、站到站查询 */

[self test :kJHAPIS_LIFE_TRAIN_S2S parameters:@{@"start":@"上海虹桥" , @"end":@"苏州园区" }];


/* 3、12306实时余票查询 */
[self test :kJHAPIS_LIFE_TRAIN_YP parameters:@{@"from":@"上海虹桥" , @"to":@"温州南" }];


/* 4、12306订票①:查询车次 */
[self test :kJHAPIS_LIFE_TRAIN_TICKET_CC parameters:@{@"from":@"上海虹桥" , @"to":@"温州南" }];


/* 5、12306订票②:提交订单 */
[self test :kJHAPIS_LIFE_TRAIN_TICKET_ORDER parameters:@{@"name":@"乘客姓名" , @"seat":@"O" , @"mobile":@"乘客手机号码" , @"idcard":@"乘客身份证号码" , @"username":@"12306官网账号" ,@"password":@"12306官网密码" , @"train_no":@"步骤①对应车次返回值" , @"station_train_code":@"步骤①对应车次返回值" , @"from_station_telecod":@"步骤①对应车次返回值" } ] ;


}

- (void)test:(NSString *)path parameters:(NSDictionary *)parameters{

JuheAPI *juheapi = [JuheAPI shareJuheApi];
[juheapi executeWorkWithAPI:path
parameters:parameters
success:^(id responseObject){
if ([[parameters objectForKey:@"dtype"] isEqualToString:@"xml"]) {
NSLog(@"***xml*** \n %@", responseObject);
}else{
int error_code = [[responseObject objectForKey:@"error_code"] intValue];
if (!error_code) {
NSLog(@" %@", responseObject);
}else{
NSLog(@" %@", responseObject);
}
}

} failure:^(NSError *error) {
NSLog(@"error: %@",error.description);
}];
}

- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}

@end


4,12306火车票查询订票接口返回数据说明以及错误码说明

1、车次查询
API :juhe.apis.train.s (宏 : kJHAPIS_LIFE_TRAIN_S)

返回字段:

名称

类型

说明

resultcode

int

返回码

reason

string

返回说明

result

dictionary

返回结果集

train_info

dictionary

返回结果集

name

string

列次名称

start

string

起点站

end

string

终点站

starttime

string

发车时间

endtime

string

到达时间

mileage

string

里程

station_list

array

站点列表

train_id

int

站点序号

station_name

string

站点名称

arrived_time

string

到达时间

leave_time

string

发车时间

stay

string

停留

mileage

string

里程

ssoftSeat

string

二等座

hardSead

string

一等座

softSeat

string

硬座

hardSleep

string

软座

softSleep

string

硬卧

error_code

int

错误码


2、站到站查询

API :juhe.apis.train.s2s (宏 : kJHAPIS_LIFE_TRAIN_S2S)

返回字段 :

名称

类型

说明

resultcode

int

返回码

reason

string

返回说明

result

dictionary

data

array

返回结果集

trainOpp

string

列次名称

train_typename

string

列车类型

start_staion

string

出发站

end_station

string

终点站

leave_time

string

发车时间

arrived_time

string

到达时间

mileage

string

里程

totalcount

int

总条数

error_code

int

错误码



3、12306实时余票查询
API :juhe.apis.train.yp (宏 : kJHAPIS_LIFE_TRAIN_YP )

返回字段 :

名称

类型

说明

error_code

int

返回码

reason

string

返回说明

result

array

返回结果集

train_no

string

车次

start_station_name

string

车次始发站

end_station_name

string

车次终点站

from_station_name

string

出发站

to_station_name

string

到达站

start_time

string

出发时间

arrive_time

string

到达时间

train_class_name

string

车次类型

day_difference

string

历时天数

lishi

string

总历时时间

gr_num

string

高级软卧:-- 说明无该席位

qt_num

string

其他

rw_num

string

软卧

rz_num

string

软座

tz_num

string

特等座

wz_num

string

无座

yw_num

string

硬卧

yz_num

string

硬座

ze_num

string

二等座

zy_num

string

一等座

swz_num

string

商务座

4、12306订票①:查询车次
API :juhe.apis.train.ticket.cc (宏 : kJHAPIS_LIFE_TRAIN_TICKET_CC )

返回字段:

名称

类型

说明

reason

string

返回说明

result

array

返回结果集

queryLeftNewDTO

dictionary


train_no

string

车次


station_train_code



start_station_telecode



start_station_name

string

车次始发站


nd_station_telecode



end_station_name

string

车次终点站


from_station_telecode



from_station_name

string

出发站


to_station_telecode



to_station_name

string

到达站


start_time

string

出发时间


arrive_time

string

到达时间


day_difference

历时天数


train_class_name

string

车次类型


lishi

string

总历时时间


canWebBuy



lishiValue



yp_info



control_train_day



start_train_date



seat_feature



yp_ex



train_seat_feature



seat_types



location_code



from_station_no



to_station_no



control_day



sale_time



is_support_card



gr_num

string

高级软卧:-- 说明无该席位


qt_num

string

其他


rw_num

string

软卧


rz_num

string

软座


tz_num

string

特等座


wz_num

string

无座


yw_num

string

硬卧


yz_num

string

硬座


ze_num

string

二等座


zy_num

string

一等座


swz_num

string

商务座

secretStr


buttonTextInfo

预订

error_code



int

错误码


5、12306订票②:提交订单
API :juhe.apis.train.ticket.order (宏 : kJHAPIS_LIFE_TRAIN_TICKET_ORDER )

返回字段 :


名称

类型

说明

reason

int

返回说明

result

dictionary

返回结果

error_code

int

错误码

6. 12306 火车票查询订票错误码


错误码

202201

车次不能

202202

查询不到车次的相信息

202203

出发站或点站不能

202204

查询不到

202205

错误的出发站名

202206

错误的到达站名

202207

查询不到余票相关数据哦

202208

错误认传递的参正确

202209

12306络错误,

202210

12306号密码错误

202211

邮箱不存在

202212

查询出

202213

提交订单

202214

出票失

202215

202216

车次无法

202217

不合法的座位类型


5, 更多聚合数据SDK接口,访问这里: http://www.juhe.cn/juhesdk/idocs

分享到:
评论

相关推荐

    Unity 广告SDK Max聚合广告SDK

    Unity 广告SDK Max聚合广告SDK是专门为游戏开发者和应用开发者设计的一款强大的工具,它集成了AppLovin MAX的功能,让开发者能够在他们的Unity项目中轻松地实现广告的变现和优化。AppLovin MAX是一个领先的广告收益...

    ios-Cocoa高德点聚合.zip

    "ios-Cocoa高德点聚合.zip"这个压缩包很可能包含了一个示例项目或者代码片段,用于演示如何在iOS应用中实现这一功能。 首先,我们要理解什么是兴趣点(POI,Point of Interest)。在地图应用中,兴趣点通常指具有...

    ios-高德自定义点标聚合.zip

    这个“ios-高德自定义点标聚合.zip”文件包含了一个关于如何在iOS应用中实现高德地图自定义点标并进行聚合的示例代码。 一、高德地图SDK介绍 高德地图iOS SDK是一个强大的地图服务工具,它允许开发者集成地图、定位...

    pingpp ios接口文档

    在iOS应用开发中,集成第三方支付接口是常见的需求,Ping++是一个流行的聚合支付服务提供商,提供了包括微信支付、支付宝、银联等多种支付方式的一站式解决方案。本文将深入解析"pingpp ios接口文档",帮助开发者...

    IOS应用源码之CiExpandableTabBar for iOS.rar

    5. **兼容性**:此库应该兼容最新的 iOS SDK,并且能够在多种设备(如 iPhone 和 iPad)以及不同尺寸的屏幕上正常工作。 6. **易于集成**:对于开发者来说,集成 CiExpandableTabBar 应该相对简单,只需导入源代码...

    flutter_plugin_toponad:TopOn聚合平台SDK的Flutter插件

    入门该项目是Flutter的起点,Flutter是一个特殊的程序包,其中包括针对Android和/或iOS的平台特定的实现代码。 要获得Flutter入门方面的帮助,请查看我们的,其中提供了教程,示例,有关移动开发的指南以及完整的API...

    MapTest.Zip

    "MapTest.Zip"这个压缩包文件显然包含了一个关于如何在iOS应用中实现高德地图点聚合的示例。点聚合技术是一种优化大量数据在地图上显示的方法,它允许我们在小范围内以聚合图标的形式展示众多的点,而在用户放大地图...

    支付的ping++

    "支付的ping++"指的是Ping++,一个专为开发者设计的支付聚合平台,它提供了丰富的API接口和SDK,使得开发者可以快速集成多种支付方式,如微信支付、支付宝、银联等,到自己的应用中。在最新的Ping++ SDK中,包含了...

    今日头条demo(带数据)

    这通常意味着开发者或学习者可以通过这个demo来了解和学习如何使用今日头条的API、数据接口或者SDK,进行新闻资讯类应用的开发和数据展示。"带数据"这一关键词暗示了该demo不仅包含了源代码,还可能包含用于测试和...

    一个简单的rss阅读器.zipIOS应用例子源码下载

    这是一个关于iOS应用开发的资源,特别是一个简单的RSS阅读器的源码示例。RSS(Really Simple Syndication)是一种用于发布和订阅网站内容的XML格式,它允许用户通过聚合器应用程序来跟踪更新,而无需直接访问每个...

    SensoroSDKDemo

    3. **实时数据流处理**:Sensoro的设备可能持续生成数据,SDK可能包含处理这些实时数据的工具,如数据过滤、聚合和通知机制。 4. **用户界面组件**:为了简化开发过程,SDK可能提供了预构建的UI控件,用于显示设备...

    实现友盟第三方登录,分享,推送demo

    在本文中,我们将深入探讨如何实现友盟第三方登录、分享及推送功能,并通过一个名为"TestDemo"的示例项目来展示其实现过程。友盟是中国一家提供移动互联网服务的公司,其产品包括社交分享、消息推送、数据分析等多个...

    (资料汇总)ESP8266系列模组SDK示例/AT指令开发/ESP8266常见问题等-电路方案

    ESP8266系列模组SDK示例/AT指令开发/ESP8266常见问题等资料截图,见附件下载: ESP8266系列模块核心处理器 ESP8266 在较小尺寸封装中集成了业界领先的 Tensilica L106 超低功耗 32 位微型 MCU,带有 16 位精简模式,...

    百度地图轨迹demo

    【标题】"百度地图轨迹demo"是一个基于百度地图API实现的示例项目,它展示了如何在Android或iOS平台上记录和展示用户的移动轨迹。这个项目对于开发者来说,是学习和理解百度地图服务,尤其是轨迹追踪功能的一个很好...

    微信公众平台与小程序开发 从零搭建整套系统.part1

    7.4.1 聚合支付接入示例 101 7.5 小结 105 第8章 微信登录 8.1 微信开放平台 107 8.1.1 UnionID机制 108 8.2 微信自动登录 109 8.2.1 数据结构设计 110 8.2.2 代码实现 112 8.2.3 使用UnionID登录...

    微信公众平台与小程序开发 从零搭建整套系统.part2

    7.4.1 聚合支付接入示例 101 7.5 小结 105 第8章 微信登录 8.1 微信开放平台 107 8.1.1 UnionID机制 108 8.2 微信自动登录 109 8.2.1 数据结构设计 110 8.2.2 代码实现 112 8.2.3 使用UnionID登录...

    实现自定义地图上面的图标

    通过学习和理解这个源码示例,开发者不仅可以掌握在iOS上实现自定义地图图标的技能,还能了解到如何处理地图数据、优化性能以及增加用户交互性,这对于任何涉及地图功能的iOS应用都是必不可少的知识。

    APICloud工具

    2. **一站聚合功能**:APICloud平台提供了丰富的API接口,覆盖了地图、支付、推送、社交网络等多种功能,开发者无需单独集成各个SDK,只需简单调用API,即可实现所需功能,大大节省了开发时间和精力。 3. **多平台...

    开发者头条第三天

    6. **移动开发**:Android和iOS的最新SDK、开发工具及设计规范,如Flutter跨平台开发,iOS的Swift语言新特性等。 7. **DevOps**:持续集成/持续部署(CI/CD)工具如Jenkins,容器化技术Docker和Kubernetes,以及自动...

    GaodeMapDemo.rar

    在移动应用开发领域,地图服务是不可或缺的一部分,而高德地图作为国内领先的地图服务商,提供了丰富的API和SDK,为开发者提供了强大的地图集成能力。"GaodeMapDemo.rar"这个压缩包文件,正是一个关于高德地图API...

Global site tag (gtag.js) - Google Analytics