|
<html>
<head>
<title>天气预报模块</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<link href="CSS/style.css" rel="stylesheet">
</head>
<body>
<?php
//载入公共文件
require_once './common.php';
//调用省份,城市和代码的数组表文件
require_once S_ROOT.'./citycode.inc.php';
$country = '';//初始化变量
$weather = array();//定义数组
//如果传入城市编码参数,则根据该参数获取指定城市信息
if (isset($_GET['citycode']) && $_GET['citycode']!='' && strlen($_GET['citycode'])<6) {
$city = getcitybycode($_GET['citycode'],$p,$c,$n);
}elseif(isset($_COOKIE['citycode']) && $_COOKIE['citycode']!='') {
$city = getcitybycode($_COOKIE['citycode'],$p,$c,$n);
}
unset($country, $p, $c, $n);//销毁指定的变量
$htmlarr = get_cma_html($city['0']);
if(!is_array($htmlarr) || empty($htmlarr)){
die('读取中央气象局天气信息失败!');
}
//将读取的数据存储到XML中
$data_dir = DATAPATH.$city[3].'/';
$live_file = $data_dir.'live_'.$city['0'].'.xml';//将读取的天气信息存储到XML文件中
$cma_file = $data_dir.'cma_'.$city['0'].'.xml';//将读取的天气指数存储到XML文件中
if (!$cfg['cache']){
//无缓存,每次更新
$live_weather = get_live_weather($htmlarr);
$cma_weather = get_cma_weather($htmlarr);
} else {
mk_dir($data_dir);
if (!@file_exists($live_file)|| date("Ymd")>date("Ymd",filemtime($live_file)) || ($_SGLOBAL['timestamp']-filemtime($live_file))>$cfg['lw_cachetime']) {
@unlink($live_file);
//获取实况天气信息,并保存
$live_weather = get_live_weather($htmlarr);
save_weather_xml($live_weather, $live_file, 0);
} else {
$live_weather = read_weather_xml($live_file, 0);
}
if (!@file_exists($cma_file) || date("Ymd")>date("Ymd",filemtime($cma_file)) || ($_SGLOBAL['timestamp']-filemtime($cma_file))>$cfg['w_cachetime']) {
@unlink($cma_file);
//获取未来三日天气信息和指数查询,并保存
$cma_weather = get_cma_weather($htmlarr);
save_weather_xml($cma_weather, $cma_file, 1);
} else {
$cma_weather = read_weather_xml($cma_file, 1);
}
}
unset($htmlarr);//销毁指定的变量
foreach ($cma_weather['cma']['gif'] as $k => $v) {//遍历天气数组元素
list($gif[$k][0],$gif[$k][1]) = explode(',', $v);
}
?>
<table width="1004" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<td width="258" height="144" rowspan="3" background="images/index_01.gif"> </td>
<td width="746" height="50" valign="top" background="images/index_02.gif"> </td>
</tr>
<tr>
<td width="746" height="34" valign="top" background="images/index_03.gif"> </td>
</tr>
<tr>
<td width="746" height="60" valign="top" background="images/index_05.gif"> </td>
</tr>
<tr>
<td colspan="2" valign="top">
<?php
define("_TPLPath_", S_ROOT.'./templates/');//定义模板路径
include template('weather.htm');//调用模板文件
?>
</td>
</tr>
<tr>
<td height="31" colspan="2" background="images/index_19.gif"> </td>
</tr>
</table>
</body>
</html>
<?php
if(!defined('IN_WEATHER')) {
exit('Access Denied');
}
// 通过用户指定的城市编码获取该城市信息,$citycode为城市编码,$p为省份数组,$c为城市数组,$n为城市编码数组
function getcitybycode($citycode,$p,$c,$n){
$flag = true;
foreach($n as $k => $arr){
if(in_array($citycode,$arr)){
$pkey = $k;
$flag = false;
break;
}
}
if($flag){
$pkey = '0';
$ckey = '0';
$citycode = $n[$pkey][$ckey];
}else{
$ckeyarr = array_keys($n[$pkey],$citycode);
$ckey = $ckeyarr[0];
}
$city = array($citycode,$p[$pkey],$c[$pkey][$ckey],$pkey);
return $city;
}
//通过用户ip得到用户所在位置,然后获取该城市信息,$citycode为城市编码,$p为省份数组,$c为城市数组,$n为城市编码数组
function getcitybyip($country,$p,$c,$n){
$pkey = getkey($p,$country); //获取省份数组下标
$ckey = getkey($c[$pkey],$country); //获取城市数组下标
$code = $n[$pkey][$ckey]; //取得相应省份所属的城市在中央天气预报信息库中的编码
$city= array($code,$country,$c[$pkey][$ckey],$pkey);
return $city;
}
function getkey($arr,$country){//获取数组的下标
if(is_array($arr)){
foreach($arr as $key => $val){
if(preg_match('/('.$val.')/',$country,$match)){
return $key;
}
}
}else{
if(preg_match('/('.$arr.')/',$country,$match)){
return $key;
}
}
return 0;
}
function mk_dir($dir) {//创建文件夹,@param $dir 文件夹路径
if(!@file_exists($dir)) {
@mkdir($dir, 0777);
}
}
/**
* 功能: 通过城市编码从中国气象局天气预报页面读取信息
* 参数: $citycode为城市编码
* 说明: 返回包含天气信息数组
*/
function get_cma_html($citycode) {
for ($i=0; $i<10; $i++) {
//中国气象局天气数据
if (false != ($htmlarr = file('http://www.cma.gov.cn/tqyb/weatherdetail/'.$citycode.'.html'))) {
return $htmlarr;
}
}
return false;
}
/**
* 功能: 从天气数组中提取实况天气信息
* 参数: $htmlarr为天气信息文本
* 说明: 返回实况天气信息数组
*/
function get_live_weather($htmlarr) {
$weather = array();
$weather['date'] = strip_tags($htmlarr[660]);
$weather['city'] = strip_tags($htmlarr[670]);
$weather['weather'] = strip_tags($htmlarr[674]);
$weather['temperature'] = strip_tags($htmlarr[675]);
$weather['wind'] = strip_tags($htmlarr[681]);
$weather['air'] = strip_tags($htmlarr[682]);
$weather['ultraviolet'] = strip_tags($htmlarr[683]);
$weather['a'] = strip_tags($htmlarr[684]);
$weather['gif'] = eregi_replace('(.+)*/tqyb/img/weather/(.+)*" width="20" height="20"></li>', "\\2", $htmlarr[671]);
return $weather;
}
/**
* 功能: 从天气数组中提取三日天气信息
* 参数: $htmlarr为天气信息文本
* 说明: 返回天气信息数组
*/
function get_cma_weather($htmlarr){
$waather = array();
list($dateregine,$weather['city']) = explode(" ",strip_tags($htmlarr['861']));
$arr['date'] = array($htmlarr['871'],$htmlarr['872'],$htmlarr['873']);
$arr['weather'] = array($htmlarr['883'],$htmlarr['890'],$htmlarr['897']);
$arr['temperature'] = array($htmlarr['917'],$htmlarr['918'],$htmlarr['919']);
$gif['gif'] = array($htmlarr['882'],$htmlarr['889'],$htmlarr['896']);
$winddirect = array($htmlarr['925'],$htmlarr['926'],$htmlarr['927']);
foreach($arr as $k => $v){
foreach($v as $key => $val){
$weather['cma'][$k][$key] = strip_tags($val);
}
}
foreach($winddirect as $k => $v){
$weather['cma']['winddirect'][$k] = htmlspecialchars(eregi_replace('(.+)*"b-cn">(.+)*</td>',"\\2",$v));
}
foreach ($gif['gif'] as $k => $v) {
$weather['cma']['gif'][$k] = eregi_replace('(.+)*/tqyb/img/weather/(.+)*" width="20" height="20"> <img src="/tqyb/img/weather/(.+)*" width="20" height="20"></td>',"\\3,\\2",$v);
}
return $weather;
}
/**
* 功能: 从文本中提取指数查询
* 参数: $htmlarr为天气信息文本
* 说明: 返回指数查询数组
*/
function get_zscx_weather($htmlarr) {
$zscx = array('cyzs'=>$htmlarr['974'],'gmzs'=>$htmlarr['978'],'clzs'=>$htmlarr['982'],'jtzs'=>$htmlarr['986'],'zszs'=>$htmlarr['990'],'gyzs'=>$htmlarr['994'],'fszs'=>$htmlarr['998'],'lxzs'=>$htmlarr['1002']);
foreach ($zscx as $k => $v) {
$weather[$k] = eregi_replace('(.+)*title="(.+)*">(.+)*</a></td>',"\\2",$v);
}
return $weather;
}
/**
* 功能: 从指定的路径读取存储有天气信息的xml文件
* 参数: $filepath为文件路径
* 说明: 返回天气信息数组
*/
function read_weather_xml($filepath, $mod=0){
$w = simplexml_load_file($filepath);
if ($mod == 0) {
$weather['city'] = $w->city;
$weather['date'] = $w->date;
$weather['weather'] = $w->weather;
$weather['temperature'] = $w->temperature;
$weather['wind'] = $w->wind;
$weather['air'] = $w->air;
$weather['ultraviolet'] = $w->ultraviolet;
$weather['gif'] = $w->gif;
foreach ($weather as $k => $v) {
$weather[$k] = iconv("utf-8","gb2312",$v);
}
} elseif ($mod == 1) {
$weather['city'] = iconv("utf-8","gb2312",$w->city);
$i = 0;
foreach ($w->data as $k => $v) {
foreach ($v as $key => $val) {
$weather['cma'][$key][$i] = iconv("utf-8","gb2312",$val);
}
$i++;
}
foreach ($w->zscx as $v){
foreach ($v as $key => $val) {
$weather['zscx'][$key] = iconv("utf-8","gb2312",$val);
}
}
}
return $weather;
}
/**
* 功能: 将天气信息存储为指定的xml文件
* 参数: $w为该城市天气信息,$filepath为文件路径,$mod=0是表示实况天气信息,$mod=1为未来三日天气信息
*/
function save_weather_xml($w, $filepath, $mod=0){
$dom = new DomDocument();
$xmlstr = '<?xml version="1.0" encoding="gb2312"?>';
$xmlstr .= "<weatherinfo>";
if ($mod == 1) {
$xmlstr .= "<city>".$w['city']."</city>";
$datasize = count($w['cma']['date']);
for($i=0; $i<$datasize; $i++){
$xmlstr .= "<data>";
$xmlstr .="<date>".$w['cma']['date'][$i]."</date>";
$xmlstr .="<weather>".$w['cma']['weather'][$i]."</weather>";
$xmlstr .="<temperature>".$w['cma']['temperature'][$i]."</temperature>";
$xmlstr .="<winddirect>".$w['cma']['winddirect'][$i]."</winddirect>";
$xmlstr .="<gif>".$w['cma']['gif'][$i]."</gif>";
$xmlstr .="</data>";
}
} elseif ($mod == 0) {
foreach ($w as $k => $v) {
$xmlstr .= "<".$k.">".$v."</".$k.">";
}
}
$xmlstr .="</weatherinfo>";
$dom->loadXML($xmlstr);
$dom->save($filepath);
}
//模板调用
function template($tplfile, $tplpath = '', $tplcachepath = '', $userpack = '', $userpackpath = '') {
$tplpath = $tplpath != '' ? $tplpath : (defined("_TPLPath_") ? _TPLPath_ : '');
$tplfile = $tplpath.$tplfile;
$tplcachelimit = defined("_TPLCacheLimit_") ? _TPLCacheLimit_ : 0;
$cachefile = ($tplcachepath != '' ? $tplcachepath : (defined("_TPLCachePath_") ? _TPLCachePath_ : '')).str_replace(array('/', '.'), '_', $tplfile.($userpack ? '.'.($userpackpath ? $userpackpath : '').$userpack : '')).'.php';
$cachetime = @filemtime($cachefile);
if (@filemtime($tplfile) <= $cachetime && (!$tplcachelimit || time() - $cachetime <= $tplcachelimit)) return $cachefile;
include S_ROOT.'./libs/nemo.php';
$nemotpl = new nemo;
$nemotpl->userpack = $userpack ? ($userpackpath ? $userpackpath : $tplpath).$userpack.'.php' : '';
$nemotpl->template = file_get_contents($tplfile);
$nemotpl->cachefile = $cachefile;
$nemotpl->extraparms = ',\\\''.$tplpath.'\\\',\\\''.$tplcachepath.'\\\',\\\''.$userpack.'\\\',\\\''.$userpackpath.'\\\'';
return $nemotpl->compile();
}
?>
|
|