java 单机接口限流处理方案
356
2022-11-04
列车查询API(列车查询火车票查询)
本文目录一览:
您好:
站长功能需要站长通过身份认证和域名认证方可开通,通过认证的站长可以为自己的域名申请开通 115.com 为站长用户提供的网站功能拓展服务(如:列车时刻查询 API),给自己的网站增加更多精彩功能。
开通站长功能前提是你要有属于自已的空间(服务器)并建设好网站.
验证流程---登陆115网盘---点击右上角的"我的帐户"----继续点击下方的"添加站点"--填写贵站的相关信息---填写完成后提交---下载验证文件保存---然后把文件上传到网站根目录下,使验证文件可以通过 “http://您的域名/您的验证文件名” 访问(验证完成后请勿删除)---点击“开始验证”按钮---验证成功后---点击右边的"获取 列车时刻查询 API 密钥"--勾选"
我已经同意了服务条款 "---申请开通---然后会获得相关列车时刻查询 API密钥,然后在后台相关插件功能处输入密钥,就可以使用列车时刻查询表了.
公交导航功能是告诉使用者从A到B的公交出行方案,而不是某条具体的公交线路信息,这一点需要广大开发者注意。
公交导航功能通过类TransitRoute来实现,这里需要说说为啥不是BusRoute,而是TransitRoute。百度提供的是公共交通导航,公共交通不仅仅涉及bus,可能还会有地铁、渡轮甚至以后的飞机火车,所以这里使用的是public transit中的transit进行描述。
一个简单的例子
我们还是从一个简单的例子开始:
var transit = new BMap.TransitRoute('北京', { renderOptions: { map: map, panel: 'panel' }});transit.search('颐和园', '西单');
代码通过renderOptions设置渲染的地图实例和侧栏面板容器的id,其中map是已经实例化好的地图,panel为已经准备好的div元素的id。我们会看到如下结果:
地图上显示了一个方案,在面板中列出了所有方案的描述,点击不同的方案地图会予以展示。
除了使用字符串类型以外,还可以提供坐标进行查询,这样可以得到更精确的结果。比如从“麦当劳”到“肯德基”这样的路线查询就不会得到结果,因为API不知道是从哪个麦当劳到哪个肯德基。下面的示例使用了坐标进行搜索。
transit2.search(new BMap.Point(116.315157,39.987946), new BMap.Point(116.371499,39.880394));
下面是使用坐标作为参数进行查询得到的结果:
注意,由于提供的是坐标,所以起点和终点没有具体的地点描述。
自定义覆盖物展示
如果你不满意API提供的默认线路的颜色和标注的样式,你也可以选择通过通过数据接口自行创建。注意,自己创建覆盖物时,点击列表中的方案将不会更新地图区域,因为此时地图区域的元素都是由开发者自行创建的。在使用数据接口之前,先通过一个结构图来了解一个完整的公交方案的各个组成部分,以方便理解:
一个不需要换乘的公交方案是由:起点、起点到上车站的步行线路、上车站到下车站的公交线路以及下车站到终点的步行线路构成。当然有可能起点和上车站是重合的,或者终点和下车站是重合的,此时步行线路长度就为0(起点或终点本身就为公交站的时候)。如果有换乘,那么每次换乘中的下车站到上车站也有步行线路(如上图的第二个方案所示)。
所以不论公交方案具体是什么样,在数据上的表示都是一致的:
•直达方案:2条步行线路 + 1条公交线路
•换乘一次方案:3条步行线路 + 2条公交线路
•换乘两次方案:4条步行线路 + 3条公交线路
以此类推。
API中通过TransitRouteResult来描述公交导航结果,通过TransitRoutePlan来描述一条公交方案。那么怎么获取公交导航结果和具体的方案的信息呢?请看下面的示例:
var transit = new BMap.TransitRoute('北京', { onSearchComplete: function(result) { if (transit.getStatus() == BMAP_STATUS_SUCCESS) { // 从结果对象中获取起点和终点信息 var start = result.getStart(); var end = result.getEnd(); addStart(start.point, start.title); addEnd(end.point, end.title); // 直接获取第一个方案 var plan = result.getPlan(0); // 遍历所有步行线路 for (var i = 0; i plan.getNumRoutes(); i++) { if (plan.getRoute(i).getDistance(false) 0) { // 判断只有大于0的步行线路才会绘制 addWalkRoute(plan.getRoute(i).getPath()); } } // 遍历所有公交线路 var allLinePath = []; for (i = 0; i plan.getNumLines(); i++) { allLinePath = allLinePath.concat(plan.getLine(i).getPath()); addLine(plan.getLine(i).getPath()); } // 最后根据公交线路的点设置地图视野 map.setViewport(allLinePath); } }});transit.search('清华大学', '北京交通大学');// 添加起点覆盖物function addStart(point, title){ map.addOverlay(new BMap.Marker(point, { title: title, icon: new BMap.Icon('', new BMap.Size(38, 41), { anchor: new BMap.Size(4, 36) })}));}// 添加终点覆盖物function addEnd(point, title){ map.addOverlay(new BMap.Marker(point, { title: title, icon: new BMap.Icon('', new BMap.Size(38, 41), { anchor: new BMap.Size(4, 36) })}));}// 添加路线function addWalkRoute(path){ map.addOverlay(new BMap.Polyline(path, { strokeColor: 'black', strokeOpacity: 0.7, strokeWeight: 4, strokeStyle: 'dashed', enableClicking: false }));}function addLine(path){ map.addOverlay(new BMap.Polyline(path, { strokeColor: 'blue', strokeOpacity: 0.6, strokeWeight: 5, enableClicking: false }));}
在上面的代码中,通过TransitRouteOptions的onSearchComplete属性设置了回调函数,一旦检索完成这个回调函数就会被调用。在回调函数开始我们先判断检索是否成功,如果成功表示至少有一条公交方案返回,这里我们先通过结果对象获取起点和终点,接着直接获取第一条方案,遍历方案中所有步行线路和公交线路并绘制在地图上,最后我们根据公交线路的点来设置一个合适的地图视野。
你会在浏览器中得到如下效果:
在获取结果对象时,除了通过回调函数参数获取以外,还可以通过TransitRoute的getResults方法获得,需要注意的是,由于搜索过程是异步的,以下代码的写法将不会得到结果:
transit.search('西单', '颐和园');var res = transit.getResults(); // undefined
因为search方法调用结束后搜索结果并没有立即返回。开发者可以在回调函数中调用此方法立即获得结果,也可以等回调函数执行完若干时间后再想获取结果数据时调用。
自定义方案描述
通过TransitRoutePlan的getDescription可以获得完整的方案描述,但是如果开发者想自行定义描述的形式则可通过数据接口进行。例如:
var transit = new BMap.TransitRoute('北京', { onSearchComplete: function(result) { if (transit.getStatus() == BMAP_STATUS_SUCCESS) { // 从结果对象中获取起点和终点信息 var start = result.getStart().title; var end = result.getEnd().title; // 直接获取第一个方案 var plan = result.getPlan(0); // 获取步行线路与公交线路个数总和,用于遍历 var total = plan.getNumRoutes() + plan.getNumLines(); var description = ['从' + start]; var addEndTitle = true; for (var i = 0; i total; i++) { if (i % 2 == 0) { // i为偶数 // 处理第一个步行描述逻辑 if (i / 2 == 0) { if (plan.getRoute(i / 2).getDistance(false) == 0) { description = ['从']; } } // 处理最后一个步行描述逻辑 if (i / 2 == plan.getNumRoutes() - 1) { if (plan.getRoute(i / 2).getDistance(false) == 0) { addEndTitle = false; } } if (plan.getRoute(i / 2).getDistance(false) 0) { description.push('步行约' + plan.getRoute(i / 2).getDistance(true) + '至'); } } else { // i为奇数 var line = plan.getLine((i - 1) / 2); description.push(line.getGetOnStop().title + ', '); description.push('乘坐' + line.title + ', '); description.push('经过' + line.getNumViaStops() + '站'); description.push('在' + line.getGetOffStop().title + '站下车,'); } } if (addEndTitle) { description.push(end + '。'); } // 替换可能出现的末尾位置的逗号 var descriptionStr = description.join('').replace(/\uff0c$/, '。'); } }});transit.search('清华大学', '北京交通大学');
变量descriptionStr的内容为:“从清华大学步行约830米至五道口, 乘坐地铁13号线(东直门-西直门), 经过3站在西直门站下车,步行约310米至城铁西直门站, 乘坐运通105(上地环岛东-中苑宾馆), 经过2站在北京交通大学站下车。”
回调函数详解
前面的几个例子我们使用了onSearchComplete回调函数,在API中还提供了如下几个回调函数,它们的含义和触发时机如下:
•onMarkersSet:如果设置了渲染的地图,则API自动添加标注后会触发此函数。
•onPolylinesSet:如果设置了渲染的地图,则API自动添加线路覆盖物后会触发此函数。
•onInfoHtmlSet:如果设置了渲染地图,当用户点击标注弹出信息窗口时会触发此函数。
•onResultsHtmlSet:如果设置了渲染侧栏,则API填充完HTML后会触发此函数。
登陆12306
点击右上角的注册
根据提示填写相关信息,提交,注册成功
进入12306,点击右上角的”车票预订“
填写出发地,目的地,出发日,点击查询
选择相应的车次,点击”预订“
选择乘车人,选择席别,提交
30分钟内支付票款,否则订单取消(支付宝、网银均可支付)
记得采纳答案
您好:
站长功能需要站长通过身份认证和域名认证方可开通,通过认证的站长可以为自己的域名申请开通 115.com 为站长用户提供的网站功能拓展服务(如:列车时刻查询 API),给自己的网站增加更多精彩功能。
开通站长功能前提是你要有属于自已的空间(服务器)并建设好网站.
验证流程---登陆115网盘---点击右上角的"我的帐户"----继续点击下方的"添加站点"--填写贵站的相关信息---填写完成后提交---下载验证文件保存---然后把文件上传到网站根目录下,使验证文件可以通过 “http://您的域名/您的验证文件名” 访问(验证完成后请勿删除)---点击“开始验证”按钮---验证成功后---点击右边的"获取 列车时刻查询 API 密钥"--勾选" 我已经同意了服务条款 "---申请开通---然后会获得相关列车时刻查询 API密钥,然后在后台相关插件功能处输入密钥,就可以使用列车时刻查询表了.
我目前用的最好的是“极品列车时刻表”有火车和飞机的,挺专业的,免费,定期更新,百度一下下载即可。
关于列车查询API和列车查询火车票查询的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注迈希泽CE认证机构。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~