进入旧版 | 服务项目 | 成功案例 | 联系方式 | 过客留言 | 友情链接
   
设为首页
加入收藏
联系我们
网站首页 | 新闻资讯 | 操作系统 | 办公软件 | 网络软件 | 工具软件 | 媒体动画 | 网页制作 | 网站开发 | 程序开发 | 平面设计
Photoshop视频教程 | Word入门 | Flash入门 | JScript | VBScript | ASP | PHP | ADO | 网页特效 | 3DS MAX6.0命令 | 系统进程
您当前的位置:GOODSGY电脑学习网 -> 网页制作 -> 其它 -> 文章内容  
根据IP获取当地天气预报的实现

访问www.163.com,首页的栏目里有当地的天气预报。可以猜想,这里的天气预报,应该是根据来访者的ip判断其所在地给出当地的天气情况。问了一些朋友,也证实了这一点。项目里也需要天气预报这个小栏目,同事做过一个(从其他站点抓取的),不过实现不了根据IP显示当地的天气情况,需要用户自行选择,而且抓取的站点属于小站….其可靠性值得怀疑。。所以就萌生了抓取网易的天气预报的想法。。。对页面进行分析。。发现显示天气预报的区域是一个IFrame,IFrame里嵌入了如下链接http: //news.163.com/util/position1.html,对这个地址访问直接跳转到另外一个链接http://news.163.com/weather/news/qx1/56294.html,此链接显示了天气情况,如图:www.goodsgy.com

1.JPGwww.goodsgy.com

  由此可以推测http://news.163.com/util/position1.html,是在根据来访者的IP判断所属区域,然后返回一个该地区所对应的区位码,如: 56294代表成都。如何让网易来帮我们的站点来访者判断所属区域,并给出天气情况,并显示在自己的站点页面上呢?还得继续分析。。因为http: //news.163.com/util/position1.html,此链接一访问就转向到天气情况的链接,而无法查看源码。便猜想。。此页面肯定有些东西。。无奈之下。。WebRequest一下,出现了如下代码:www.goodsgy.com

www.goodsgy.com

以下是引用片段:
 1<script language="Javascript">  
 2var city = new Array("安徽","黑龙江","山东","北京","湖北","山西","福建","湖南","陕西","甘肃","吉林","上海","广东","江苏","四川","广西","江西","天津","贵州","辽宁","西藏","海南","内蒙古","新疆","河北","宁夏","云南","河南","青海","浙江","重庆");  
 3var weaths = new Array('58321','50953','54823','54511','57494','53772','59134','57679','57036','52889','54172','58367','59287','58238','56294','59431','58606','54527','57816','54342','55591','52856','53463','51463','53698','53614','56778','57083','52866','58457','57516'); 
 4 
 5function getCookieVal (offset) { 
 6  var endstr = document.cookie.indexOf (";", offset); 
 7  if (endstr == -1) 
 8  endstr = document.cookie.length; 
 9  return unescape(document.cookie.substring(offset, endstr)); 
10} 
11function GetCookie (name) { 
12  var arg = name + "="; 
13  var alen = arg.length; 
14  var clen = document.cookie.length; 
15  var i = 0; 
16  while (i < clen) { 
17    var j = i + alen; 
18    if (document.cookie.substring(i, j) == arg) 
19      return getCookieVal (j); 
20    i = document.cookie.indexOf(" ", i) + 1; 
21    if (i == 0) 
22       break; 
23  } 
24  return ""; 
25} 
26function SetCookie(cookieName,cookieValue,nDays) { 
27 var today = new Date(); 
28 var expire = new Date(); 
29 if (nDays==null || nDays==0) nDays=1; 
30 expire.setTime(today.getTime() + 3600000*24*nDays); 
31 document.cookie = cookieName+"="+escape(cookieValue) + ";path=/;domain=.163.com;expires="+expire.toGMTString(); 
32} 
33function getCityWeatherID(cityname){ 
34    for(i=0;i<city.length;i++){ 
35    if(city[i]==cityname){ 
36        return weaths[i]; 
37        } 
38    } 
39    return "54511"; 
40} 
41 
42var NTES_WeatherAddr = GetCookie("NTES_WeatherAddr"); 
43if (!NTES_WeatherAddr){ 
44    var loc = GetCookie("theaddr"); 
45    if(!loc){ 
46        document.write("<script type='text/javascript' src='http://202.108.39.152/ipquery'>;<" + "/script>"); 
47    } 
48} 
49</script> 
50<script> 
51if (!NTES_WeatherAddr){ 
52    NTES_WeatherAddr=getCityWeatherID(loc); 
53} 
54window.location.href="http://news.163.com/weather/news/qx1/"+NTES_WeatherAddr+".html"; 
55</script> 
56 
57

  上面的这段js实现了对来访者IP判断并给出了天气预报结果的链接。Js里的此链接: http://202.108.39.152/ipquery,起到的是判断用户所在地的作用,返回的是来访者所在地省份。分析到此,想要的结果差不多就出来了…www.goodsgy.com

  在客户端调用这段js获得天气预报结果的链接地址,然后交给服务端来处理。(为什么要交给后台处理,而不是直接显示呢?)因为直接得出的链接页面上,有多余的链接,还应用了样式(如图一),不便为自己所用,所以得处理掉。客户端调用服务端的方法很多,最初使用了Ajax框架Anthem,实现了过后,觉得有点杀鸡用牛刀的感觉。。无聊之余。。就又用CallBack实现了一次。。感觉恰到好处。。后来又发现。。__doPostBack也可以实现客户端调用服务端方法。。看来实现这么一个功能还真是简单。。。www.goodsgy.com

  好了到此就实现了,自己想要的结果:(感觉有点遗憾的是只给出了省会城市的天气预报)www.goodsgy.com

2.JPGwww.goodsgy.com

www.goodsgy.com

[1] [2]  下一页

在百度中搜索:根据IP获取当地天气预报的实现
在Google中搜索:根据IP获取当地天气预报的实现
在Yahoo中搜索:根据IP获取当地天气预报的实现

收藏到网摘:新浪VIVI 365key 我摘 POCO网摘 博采中心 YouNote 和讯网摘 天天收藏
[] [返回上一页] [打 印] [收 藏]

 相关文章    最新文章
· 在Vista中根据日期查找图片
· 根据分辨率不同调用不同的css文件
· 根据IP自动获取所在地天气预报
· C# 制作出任意不规则按钮! (原理根据背景..
· 根据html页面模板动态生成html页面(c#类)..
· 将网页内容保存为字符串以及根据字符串显..
· Visio 2003 教程 根据办公室号码列表创建..
· 根据xsd生成xml文档
· AJAX实例:根据邮编自动完成地址信息
· 父DIV的高度不能根据子DIV自动变化的解决..
 
· Google搜索引擎:迈向云计算的未来
· 一个合格网页设计师的标准是什么?
· 建立自己的博客的过程中学习到的知识
· 网站策划:网站栏目和页面的策划
· 初学:关于域名和空间的一些认识
· 什么是静态网页和动态网页?
· 设计网页前端界面必备的技能
· 如何调用Flash才符合Web网页标准?
· 网页色彩的搭配
· 文章内容SEO优化基本原则

∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [更多评论…]
站内搜索

精彩图文
  网站导航  
操作系统 办公软件 网络软件
Vista Windows2003 WindowsXP Windows2000/NT Windows9X/ME Linux 其他 Word Excel Powerpoint Outlook 金山系列 其他 网页浏览 上传下载 联络聊天 邮件工具 服务器软件 网络辅助
工具软件 媒体动画 网页制作
系统工具 媒体工具 压缩工具 图文处理 文件管理 其他 3DMAX Authorware Director Maya 视频处理 其他 Flash Dreamweaver FireWorks FrontPage LiveMotion Golive HTML/CSS 其它
网站开发 平面设计 程序设计
ASP JSP PHP CGI JavaScript VBScript XML/SOAP Web服务器 Photoshop PhotoImpact CorelDraw Illustrator Freehand 设计欣赏 其他 VB VC .NET C/C++ DELPHI JAVA

冀ICP备05019428号
Copyright © 2004-2008 电脑学习网 Inc.All rights reserved.
TEL:13832340607
QQ:39873155
E_Mail:goodsgy(#)hotmail.com   (把(#)替换成@)
MSN:goodsgy(#)hotmail.com   (把(#)替换成@)