ASP获取json天气信息
ASP代码(ASP获取页面源码方法,有编码、超时时间参数,处理了乱码、超时的问题):
Function GetHttpPage(HttpUrl)
If IsNull(HttpUrl)=True Or Len(HttpUrl)< Then
GetHttpPage="$False$"
Exit Function
End If
Dim Http
'Set Http=server.createobject("MSXML2.XMLHTTP")
Set Http=server.createobject("MSxml2.ServerxmlHTTP")
Http.SetTimeOuts ,,,
Http.open "GET",HttpUrl,False
Http.Send()
If Http.Readystate<> then
Set Http=Nothing
GetHttpPage="False"
Exit function
End if
GetHTTPPage=BytesToBstr(Http.responseBody,"UTF-8")
Set Http=Nothing
If Err.number<> then
Err.Clear
End If
End Function Function BytesToBstr(Body,Cset)
Dim Objstream
Set Objstream = Server.CreateObject("adodb.stream")
objstream.Type =
objstream.Mode =
objstream.Open
objstream.Write body
objstream.Position =
objstream.Type =
objstream.Charset = Cset
BytesToBstr = objstream.ReadText
objstream.Close
set objstream = nothing
End Function
ASP方法使用(从m.weather.com.cn获取上海天气json数据):
<%
html=GetHttpPage("http://m.weather.com.cn/data/101020100.html")
'response.write(html)
%>
JS脚本将获取的数据追加到页面显示(用到了ASP和jQuery)
<script type="text/javascript">
var weather=eval(<%=html%>);
var htmlInfo="";
var dateVal="<%=year(now()) %>年<%=month(now()) %>月<%=day(now()) %>日"; if(weather!=undefined)
{
if(dateVal!=weather.weatherinfo.date_y)
{
htmlInfo="暂时无法获取最新上海天气数据 ";
}
else
{
htmlInfo=weather.weatherinfo.date_y+" "+
weather.weatherinfo.week+
" 上海天气 "+weather.weatherinfo.img_title1+
" 气温"+weather.weatherinfo.temp1+" "+
weather.weatherinfo.wind1+" "+
"紫外线“"+weather.weatherinfo.index_uv+"” "+
weather.weatherinfo.index_d;
}
}
else
{
htmlInfo="暂时无法获取上海天气数据 "
}
$("#weatherSpan").html(htmlInfo);
</script>
参考:
之后做的调整:
1. GetHttpPage方法中SetTimeOuts 2000,2000,2000,2000是后来补充的,设置了超时时间。
同时原Set Http=server.createobject("MSXML2.XMLHTTP")也改成了Set Http=server.createobject("MSxml2.ServerxmlHTTP")。
参数说明参考:http://www.zzsky.cn/build/content/1427.htm
2. 原weather.weatherinfo!=undefined的判断也不对,已经更新成weather!=undefined。
3. 增加ASP缓存处理,缓存天气信息:
ASP缓存关键代码(使用的Application,所以是全局共享缓存——参考):
CONST_CACHE_DEFAULT_INTERVAL = '每隔1小时刷新一次cache Function IsExpires(cacheName)
Dim strLastUpdate
strLastUpdate= Application(cacheName & "_LastUpdate")
If ((strLastUpdate = "") Or (CONST_CACHE_DEFAULT_INTERVAL < DateDiff("s", strLastUpdate, Now))) Then
ClearCacheData cacheName
IsExpires=true
Else
IsExpires=false
End If
End Function Sub ClearCacheData(cacheName)
Application.Lock
Application(cacheName) = ""
Application(cacheName & "_LastUpdate") = ""
Application.UnLock
End Sub Sub SetCacheData(cacheName,content)
Application.Lock
Application(cacheName) = content
Application(cacheName & "_LastUpdate") = CStr(now())
Application.UnLock
End Sub Function GetCacheData(cacheName)
If (IsExpires(cacheName)) Then
ClearCacheData cacheName
End If
GetCacheData=Application(cacheName)
End Function
使用:
JS转json的方法:
<script language="JScript" runat="Server">
function toObject(json)
{
eval("var o=" + json);
return o;
}
</script>
vbscript代码(增加了是否是当天天气的判断,使用js的方法处理json):
htmlWeather=GetCacheData("htmlWeatherInfo")
if(htmlWeather="") then
htmlWeather=GetHttpPage("http://113.108.239.107/data/101020100.html")'http://m.weather.com.cn/data/101020100.html
SetCacheData "htmlWeatherInfo",htmlWeather
'response.Write Application("htmlWeatherInfo_LastUpdate")
else
objVal=toObject(htmlWeather)
if objVal<>"" and objVal.weatherinfo.date_y<>(year(now())&"年"&month(now())&"月"&day(now())&"日") then
htmlWeather=GetHttpPage("http://113.108.239.107/data/101020100.html")'http://m.weather.com.cn/data/101020100.html
SetCacheData "htmlWeatherInfo",htmlWeather
end if
'response.Write toObject(htmlWeather).weatherinfo.date_y
'response.Write Application("htmlWeatherInfo_LastUpdate")
end if
4.如果出现http://m.weather.com.cn/data/101020100.html在实际环境无法访问可尝试换成IP地址的URL:http://113.108.239.107/data/101020100.html
5.其他天气接口页面:
http://m.weather.com.cn/m/pn1/weather.htm?id=101200101T 这个链接有15种不同格式的,从pn1到pn15,ID是需要查询的那个城市的代码(城市代码参考:中国国家气象局天气预报信息接口)
http://m.weather.com.cn/m/pn1/weather.htm 这个链接有15种不同格式的,从pn1到pn15
http://m.weather.com.cn/m/p1/weather1.htm 这个链接有13种不同格式的,从p1到p13
http://m.weather.com.cn/n/pn1/weather.htm 这个链接有14种不同格式的,从pn1到pn14
http://www.weather.com.cn/static/custom/custom.html 这个链接可以同时显示多个城市的天气
ASP获取json天气信息的更多相关文章
- Linux网络编程之"获取网络天气信息"
需求分析: 1.需要Linux c 网络编程基础, 2.需要了解 http 协议 3.需要天气信息相关api(可以从阿里云上购买,很便宜的!) 4.需要cJSON解析库(因为获取到的天气信息一般是用c ...
- qt qml ajax 获取 json 天气数据示例
依赖ajax.js类库,以下代码很简单的实现了获取天气json数据并展示的任务 [TestAjax.qml] import QtQuick 2.0 import "ajax.js" ...
- python 学习笔记 12 -- 写一个脚本获取城市天气信息
近期在玩树莓派,前面写过一篇在树莓派上使用1602液晶显示屏,那么可以显示后最重要的就是显示什么的问题了. 最easy想到的就是显示时间啊,CPU利用率啊.IP地址之类的.那么我认为呢,假设可以显示当 ...
- ASP.NET 跨域获取JSON天气数据
前几天做一个门户网站,在首页需要加载气象数据,采用了中央气象局的接口. 刚开始采用JSONP在前台跨域请求数据,没成功~ 后换成在c#后台请求数据返回... 前端代码: $(function () { ...
- 【一天一个小知识10/20】Unity通过www获取json文本信息。
前提:领导要我在unity获取局域网服务器的文本信息.给了一个json的网络文本让我测试.我对于json以及服务器比较陌生.就直接去网上找相关的资料. 以下是自己测试的代码,没问题. 测试的网络jso ...
- jmeter通过json extrcator或者正则表达式获取json返回信息
1.下载地址,及插件文档资料 https://jmeter-plugins.org/wiki/JSONPathExtractor/ json信息如下 { "error_code": ...
- 原生JS和jQuery分别使用jsonp来获取“当前天气信息”
需掌握的技能点: jsonp.跨域相关等. 以下两种代码,均可直接运行. 1.使用原生JS: <!DOCTYPE html> <html lang="en"> ...
- 利用json获取天气信息
天气预报信息获取是利用json获取的,网上有非常多资源,源码.因为上面涉及到非常多天气信息,包含湿度,出行建议等,以及加入了全部城市代码的资源包.为了练手了解json的原理.我仅获取诚笃城市的最高温, ...
- 使用小米天气API获取天气信息
1. URL部分 以下url中"%s"代表的是城市Id,比如北京的cityId=101010100: //获取未来五天预报信息,红色部分信息不需要 WEATHER_DATA_URL ...
随机推荐
- Hibernate映射集合属性
Hibernate要求持久化集合属性字段必须声明为接口,实际的接口可以是java.util.Set,java.util.Collection,java.util.List,java.util.Map, ...
- UVa 11754 (中国剩余定理 枚举) Code Feat
如果直接枚举的话,枚举量为k1 * k2 *...* kc 根据枚举量的不同,有两种解法. 枚举量不是太大的话,比如不超过1e4,可以枚举每个集合中的余数Yi,然后用中国剩余定理求解.解的个数不够S个 ...
- HTML空格符号   / &ensp / &emsp
半角的不断行的空白格(推荐使用) 半角的空格 全角的空格
- Java Servlet与Applet、CGI、JSP的比较
Java Servlet是一种独立于平台和协议的服务器端的Java应用程序,可以生成动态的Web页面. Java Servlet是位于Web 服务器内部的服务器端的Java应用程序,与传统的从命令行启 ...
- Java知识点:条件编译
条件编译 一般情况下,源程序中所有的行都参加编译.但有时希望对其中一部分内容只在满足一定条件下才进行编译,即对一部分内容指定编译条件,这就是“条件编译”(conditional compile). ...
- POJ 1833 排列
题意: 给你某个排列 求从下一个排列开始的第k个排列如果是最后一个排列 则下一个排列为1 2 3 ... n// 1 用stl 里面的 next_permutation// 2 用生成下一个排列算法/ ...
- 【MySQL for Mac】终极解决——MySQL在Mac的字符集设置
这个问题烦恼一天了,现在终于得以解决.分享给大家 首先贴出来,亲测不可行的博客连接: http://www.2cto.com/database/201305/215563.html http://bl ...
- JAVA数据库处理(连接,数据查询,结果集返回)
package john import java.io.IOException; import java.util.*; public class QueryDataRow { public Hash ...
- protobuf-3.0.0-beta-2 windows编译 x64/x86
V3.0.0 beta2以及之后都是CMake 创建VS Solution,project. 因为只能创建x64的项目工程,有时候需要x86的, 只能创建完x64后,自己修改工程配置弄成x86. 创建 ...
- 解决32位plsql客户端连接不64位Oracle11g上数据库
一.解决方案 因为本人安装的是64位的Oracle,plsql 是32位的故连接不上.网上有方法能连接. 1. 文件下载 下载PLSQL_Developer地址 http://pan.baidu.co ...