1.如何使用中国气象局API开发天气APP

2.获取天气消息的途径或方式

3.开发个ja servlet 接口,主要是处理用户查询天气预报的请求,返回相应的结果。

4.安卓开发:如何定位城市用于天气预报?

未来天气预报接口_未来天气精准播报

我今天也收到客户抱怨了,上中国天气网查看到了一个公告,看样子是API要变的节奏:

为更好地为用户提供气象数据服务,新版气象数据开放平台于2014年11月17日正式上线。

新用户可在线注册帐户,详细填写用户资料,按照申请流程提示申请数据接口,审核通过后,系统会自动分发密钥。新用户API数据接口通过审核后一年有效,逾期未续约将自动失效,API数据产品类型详见开放平台产品中心。

已申请并开通接口的老用户可继续使用原有API接口,原有API接口自今日起一年内有效,于2015年11月16日自动关闭,如有使用需要,建议老用户在接口关闭之前申请新API接口,申请流程及具体说明参见新用户申请。

请广大开发者相互转告,我们一直努力,为大家提供不断优化的气象数据服务

如何使用中国气象局API开发天气APP

你这个不是接口,只是个网页地址。

我找到另外一个天气预报的接口:

://.webxml.cn/WebServices/WeatherWebService.asmx

只要在项目中添加Web引用:

按照这个做:

然后人就可以实例化这个对象:

调用对应的方法就可以获取接口中的信息了。

直接在IE或其它浏览器中打开这接口网址:

://.webxml.cn/WebServices/WeatherWebService.asmx

可以看到那些方法的使用说明。

还是不会就不应该了。为了这15分,可以加我好友再问。

获取天气消息的途径或方式

前期的准备工作:

一、申请API(拿好id和private_key)

二、解读《SmartWeatherAPI<Lite> WebAPI版接口使用说明书》

三、准备好areaid、type、date、id、urlencode($key)(注意,这里经加密的key是需要encodeurl之后的才能成为接口链接的一部分)

好了下面的编码开始:

1、从附件中的areaid_list中找到你想要的地方的areaid,并且选择要查询天气的类型

NSString *areaid = @"101010100";

NSString *type =

@"index_f";

/**

* 官方文档更新的数据类型号

* 指数:index_f(基础接口);index_v(常规接口)

3天预报:forecast_f(基础接口);forecast_v(常规接口)

*

*/

2、获得当前天气date

NSDate

*_date = [NSDate date];

NSDateFormatter *dateFormatter =

[[NSDateFormatter alloc] init];

[dateFormatter

setDateFormat:@"yyyyMMddHHmmss"];//注意日期的格式

NSString *date =

[[dateFormatter stringFromDate:_date]

substringToIndex:12];//用到的精确到分,24小时制60分钟制

3、申请的id,和private_key

NSString *id =

@"15ds45s13a465s";//这里是楼主随便输入的,瞎编的

NSString *private_key =

@"46s4ds_SmartWeatherAPI_45s44d6";//也是瞎编的

4、算出经过urlencode后的key,这步比较重要,步骤也多,请耐心看完。

在原来的的基础上是在PHP的环境中算出的,代码如下,可在“

://writecodeonline/php/ ”下进行算法的检验

echo

urlencode(base64_encode(hash_hmac('sha1', " ://open.weather.cn/data/?areaid=101010100&type=index_f&date=201409041509&id=15ds45s13a465s",

"46s4ds_SmartWeatherAPI_45s44d6",

TRUE)));

首先定义得到public_key和API的方法,还有就是对key进行encodeurl操作的方法

注意,这里的方法都是被我定义在getTime的类里面,后面是在main中实例化出来的

//获得publicky

- (NSString*)

getPublicKey:(NSString*)areaid :(NSString*)type :(NSString*)date

:(NSString*)id {

NSString *Key = [[NSString alloc]

initWithFormat:@"://open.weather.cn/data/?areaid=%@&type=%@&date=%@&id=%@",

areaid, type, [date substringToIndex:12], id];

return

Key;

}

//获得完整的API

- (NSString*) getAPI:(NSString*)areaid

:(NSString*)type :(NSString*)date :(NSString*)id :(NSString*)key

{

NSString *API = [[NSString alloc]

initWithFormat:@"://open.weather.cn/data/?areaid=%@&type=%@&date=%@&id=%@&key=%@",

areaid, type, [date substringToIndex:12], [id substringToIndex:6],

key];

//-------------这里需要主要的是只需要id的前6位!!!

return

API;

}

//将获得的key进性urlencode操作

- (NSString

*)stringByEncodingURLFormat:(NSString*)_key{

NSString *encodedString

= (__bridge NSString

*)CFURLCreateStringByAddingPercentEscapes(kCFAllocatorDefault,(CFStringRef)_key,

nil, (CFStringRef) @"!$&'()*+,-./:;=?@_~%#[]",

kCFStringEncodingUTF8);

//由于ARC的存在,这里的转换需要添加__bridge,原因我不明。求大神讲解

return

encodedString;

}

重点来了,在oc下的算法如下,记得把附件的Base64.h

加进来并引用到工程里面

//对publickey和privatekey进行加密

- (NSString *)

hmacSha1:(NSString*)public_key :(NSString*)private_key{

NSData*

secretData = [private_key

dataUsingEncoding:NSUTF8StringEncoding];

NSData* stringData = [public_key

dataUsingEncoding:NSUTF8StringEncoding];

const void* keyBytes =

[secretData bytes];

const void* dataBytes = [stringData

bytes];

///#define CC_SHA1_DIGEST_LENGTH 20 /* digest

length in bytes */

void* outs =

malloc(CC_SHA1_DIGEST_LENGTH);

CCHmac(kCCHmacAlgSHA1, keyBytes,

[secretData length], dataBytes, [stringData length], outs);

//

Soluion 1

NSData* signatureData = [NSData dataWithBytesNoCopy:outs

length:CC_SHA1_DIGEST_LENGTH freeWhenDone:YES];

return

[signatureData

base64EncodedString];

}

这里只是初步算出来的key,还未encodeurl,链接不能被浏览器识别,所以现在经过算法得到的_key还有一步操作才能的到真正的key。

NSString *_key = [getTime hmacSha1:[getTime

getPublicKey:areaid :type :date :id] :private_key];

NSString *key =

[getTime

stringByEncodingURLFormat:_key];

最后一步了吧!拼接API

NSString *weatherAPI = [getTime getAPI:areaid :type :date

:id

:key];

//OK,我们的API就可以用啦。

最后,通过API返回的值是JSON文件,通过解析,就能得到我们想要的数据了,下面拿一个开发的接口举例

NSDictionary *weatherDic = [getTime

getWeatherDic:@"://.weather.cn/data/cityinfo/101010100.html"];

// weatherDic字典中存放的数据也是字典型,从它里面通过键值取值

NSDictionary

*weatherInfo = [weatherDic

objectForKey:@"weatherinfo"];

NSLog(@"今天是 %@ %@ %@ 的天气状况是:%@ %@ -

%@",[newDateOne substringWithRange:NSMakeRange(0, 4)],[newDateOne

substringWithRange:NSMakeRange(4, 2)] ,[newDateOne

substringWithRange:NSMakeRange(6, 2)],[weatherInfo

objectForKey:@"weather"],[weatherInfo objectForKey:@"temp1"],[weatherInfo

objectForKey:@"temp2"]);

输出:2014-09-04 23:40:23.243

WeatherAPP[5688:201108] 今天是 2014-09-04 的天气状况是:晴 17℃ - 30℃

weatherInfo字典里面的内容是--->{"weatherinfo":{"city":"北京","cityid":"101010100","temp1":"17℃","temp2":"30℃","weather":"晴","img1":"n0.gif","img2":"d0.gif","ptime":"18:00"}}

开发个ja servlet 接口,主要是处理用户查询天气预报的请求,返回相应的结果。

气象数据指标

气温:指高地面约1.5-2米处百叶箱中的温度

湿度:指高地面约1.25~2米的空气湿度

气压:指该地区的气压值

降水量:是指从天空降落到地面上的液态或固态(经融化后)水,未经蒸发、渗透、流失,而在水平面上积聚的深度

经向风:指高地面约10m风的经向分量(南风为正)

纬向风:指高地面约10m风的纬向分量(西风为正)

地面风速:指高地面约10米的风速

风向:指风的来向,正北方向为0°,顺时针为正

地表水平辐射:射入地表单位水平表面的太阳辐射总量

直接辐射:指太阳圆面和离太阳最近的区域(以太阳为中心5度的太阳圆面)放射出来的直射太阳辐射

散射辐射:指太阳光在穿过大气层到达地面过程中遇到云、气体分子、尘埃等产生散射,以漫射形式到达地球表面的辐射能

可以通过气象数据平台,查询历史四十年和预测未来七日内气象数据。如:羲和能源大数据平台 (xihe-energy)

查询步骤

步骤一:平台进行地理位置选择。可以选择全球任意位置单点数据也可以选择区域平均数据

步骤二:确认数据源。历史数据可选择羲和数源、欧洲中期天气中心、美国国家航空航天局;预测数据可选择德国气象局

步骤三:输入想查询下载的起止时间,可选历史40年和未来7日

步骤四:选择所需要的气象数据下载,导出csv格式小时级数据,保存数据可视化,也可根据需要选择API接口

步骤五:如需要查询更多数据,可在“更多属性”中进行“检索属性”

安卓开发:如何定位城市用于天气预报?

简单的方法,可以直接在servlet的doGet或doPost里面构建这个xml,然后写回响应就可以了。

需要搭建ja应用服务器如tomcat服务器,运行这个servlet就可以。

xml的构建对于Ja来说工具很多,JDOM, Dom4J等。

如果客户端要求用web service方式提供,就考虑Apache CXF这些Ja Web服务框架,不过一般没必要的。

(1)修改新建项目的res\layout目录下的布局文件main.xml,将默认添加的Text View组件删除,然后添加一个水平线性布局管理器和一个用于显示网页的Web View级件,并在该布局管理器中添加‘北京“按钮、”上海“按钮、”哈尔滨“按钮、”长春“按钮、”沈阳“按钮和”广州“按钮,具体代码请参见光盘。

(2)在MainActivity中,声明一个Web View组件的对象webView,具体代码如下:

(3)在onCreateO方法中,首先获取布局管理器中添加的Web View组件,然后设里该组件允许使用JaScript,并处理JaScript对话框和各种请求,再为Web View组件指定要加载的天气预报信息,最后将网页内容放大4倍,具体代码如下:

(4)让MainActivity实现OnClickListener接口,用于添加单击。修改后的代码如下: