C#实时天气接口
提示:可同步(后端直接请求)或异步(前端Ajax异步请求)请求,返回的是json格式的天气数据。
注意:服务器端必须要有互联网才能请求此接口。
前言
提示:这是服务器端请求数据方式,前端请求可采用Ajax调用。
一、后端请求代码
说明:http://t.weather.itboy.net/api/weather/city/城市编码(如:101270101)为接口地址,该地址可能会变更,注意关注sojson官方天气接口的地址
sojson天气接口文档地址:https://www.sojson.com/blog/305.html
代码如下:
/// <summary>
/// 根据城市编码获取天气json
/// </summary>
/// <param name="cityCode">城市编码</param>
/// <returns>天气json</returns>
protected string GetWeatherByCity(string cityCode)
{
try
{
string url = "http://t.weather.itboy.net/api/weather/city/" + cityCode;
System.Net.HttpWebRequest request = (System.Net.HttpWebRequest)System.Net.WebRequest.Create(url);
request.Timeout = 10000;
request.UserAgent = "Code Sample Web Client";
request.Credentials = CredentialCache.DefaultCredentials;
//HttpWebRequest 对象 获取GetResponse 转换成HttpWebResponse
System.Net.HttpWebResponse response = request.GetResponse() as System.Net.HttpWebResponse;
//通过HttpWebResponse response.GetResponseStream()获取输出流
System.IO.Stream str = response.GetResponseStream();
System.IO.StreamReader reader = new System.IO.StreamReader(str, System.Text.Encoding.GetEncoding("utf-8"));
string weathhtml = reader.ReadToEnd();
str.Close();
reader.Close();
return weathhtml;
}
catch (Exception)
{
return "请求异常";
}
}
二、前端请求代码
后端接口处理接口可以是api或者一般处理程序ashx,这里就不一一贴了。
前端ajax请求代码如下(返回的json结果可以自由处理输出到页面):
$.ajax({
type: "post",
url: '后端处理接口地址',
data: {
cityCode: cityCode//城市编码
},
success: function (result) {
if (result.status == 200) {//请求成功加载信息
console.log(result.data.forecast[0].type);
}
else {
console.log(result);
}
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
console.log("错误:" + XMLHttpRequest);
}
});