java调天气预报接口

[color=blue][size=medium]
1、java调用天气预报接口,参考[url]http://g.kehou.com/t1029846752.html[/url],现在比如我访问成都的天气预报,则访问地址[url]http://m.weather.com.cn/data/101270101.html[/url],就可一得到一串json数据。我们就可以对这串进行解析

如果用ajax直接访问是最简单的一种方式,但涉及到一个跨域的问题,至今都还没搞懂啊,跪求大神 :oops:
现在用java解析就变得比较简单,上代码:
[/size][/color]

@GET
@Path("/get")
@Produces(MediaType.APPLICATION_JSON)
public String getWeather() throws MalformedURLException, IOException,
JSONException {

try {
HttpURLConnection huc = (HttpURLConnection) new URL(
"http://m.weather.com.cn/data/101270101.html")
.openConnection();
huc.setRequestMethod("GET");
huc.setUseCaches(true);
huc.connect();
InputStream is = huc.getInputStream();
BufferedReader reader = new BufferedReader(
new InputStreamReader(is));
StringBuffer temp = new StringBuffer();
String str;
while ((str = reader.readLine()) != null) {
temp.append(str + "\n");
}
System.out.println(temp.toString());
is.close();
reader.close();
return temp.toString();
} catch (Exception e) {
e.printStackTrace();
} finally{

}
return null;
}


[color=blue][size=medium]
2、这里用到的是restful,无所谓用什么,我们用ajax调用到这个方法时就会返回一串json数据到前台如代码,
[/size][/color]

function getWeather() {

$.ajax({
url : 'rest/weather/get',
type : 'GET',
success : function(meta) {
var w = meta.weatherinfo;
$("#w1").empty().append("今天:"+w.weather1+" "+w.temp1+" <img src='http://www.weather.com.cn/m/i/weatherpic/29x20/d"+w.img1+".gif'></img>");
$("#w2").empty().append("明天:"+w.weather2+" "+w.temp2+" <img src='http://www.weather.com.cn/m/i/weatherpic/29x20/d"+w.img3+".gif'></img>");
$("#w3").empty().append("后天:"+w.weather3+" "+w.temp3+" <img src='http://www.weather.com.cn/m/i/weatherpic/29x20/d"+w.img5+".gif'></img>");
}
});
}

[color=blue][size=medium]
ajax可能就是解析一个json数据。。。
注:img中装的是天气预报提供的表示各种天气的图片,参考[url]http://g.kehou.com/t1029846752.html[/url] 讲的很清楚。
差不多了。。。
[/size][/color]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值