當前位置:首頁 » 網頁前端 » web天氣預報參考文獻
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

web天氣預報參考文獻

發布時間: 2023-03-21 04:07:11

A. c# winform 如何顯示天氣預報

不要聽網上這些人的風言風語,我們都是用WebBrowser來完成這個操作的,直接把url賦值給WebBrowser就了事,何必一大堆一大堆的代碼,天氣預報終究是運營商提供的,哪天他停止了服務,你又要去修改代碼,不覺得可笑嗎?

我的方法是:建立一個本地ACCESS資料庫,設置好他的密碼,在裡面做一個表,存儲各個城市url和各個城市名,url是在網站上獲取的,比如:http://tianqi.xixik.com,提供你所需要的城市天氣預報代碼:http://cache.xixik.com.cn/1/hefei/是合肥的http://cache.xixik.com.cn/1/beijing/是北京的...

你要做的事情很簡單,只需要讀取資料庫,給WebBrowser分配url就好了,資料庫放在程序相對路徑裡面,可以增刪查,防止這個網站沒用了還可以維護,打包程序的時候把資料庫格式改成.bat或者.cab,連接字元串里,也要改掉,這樣資料庫就只佔幾個KB空間。

B. 如何使用webserver實現在線天氣預報查詢

步驟 :
1 、新建web 項目,添加窗體。
2 、 引用右鍵--> 添加服務引用-->高級--> 添加Web引用。

3 、 將Web介面復制到URL右邊的框里-->點擊輸入框右邊的箭頭,測試連接(觀察左下角看是否連接成功)--> 最右邊可以更改Web引用名-->添加引用。

C. 如何獲取天氣預報的wsdl

1、天氣預報web services地址
http://webservice.webxml.com.cn/WebServices/WeatherWS.asmx?wsdl
用瀏覽器打開此地址,保存頁面為Weather.xml
2、新建一個java工程 webservices
建立包名 com.test.ws
將Weather.xml拷貝到src目錄下
3、編寫批處理WSDL-SQUARED.CMD,使用wsdj2java生成客戶端調用代碼

setAXIS_HOME=D:axis-1_4
setCLASSPATH=.;%AXIS_HOME%libaxis.jar;%AXIS_HOME%libaxis-ant.jar;%AXIS_HOME%libcommons-discovery-0.2.jar;%AXIS_HOME%libcommons-logging-1.0.4.jar;%AXIS_HOME%libjaxrpc.jar;%AXIS_HOME%liblog4j-1.2.8.jar;%AXIS_HOME%libsaaj.jar;%AXIS_HOME%libwsdl4j-1.5.1.jar
javaorg.apache.axis.wsdl.WSDL2Java-pcom.test.wsWeather.xml

D. java web service實現天氣預報功能

前台js界面代碼:

//省份
functionLoadProvince(){
$.ajax({
type:"POST",
url:"ashx/weatherHandler.ashx",
data:"option=province",
success:function(result){
$(".sel-provinceoption").remove();
vararry=result.split('|');
varobj=null;
for(vari=0;i<arry.length;i++){
if(arry[i]!=null&&arry[i]!=""){
obj=arry[i].split(',');
$(".sel-province").append("<optionvalue='"+obj[1]+"'>"+obj[0]+"</option>");
}
}
$(".sel-province").find("option[text='北京']").attr("selected","selected");
},
error:function(errorMsg){
$(".result-tabletr").remove();
$(".result-table").append("<tr><td>省份請求出現錯誤,請您稍後重試。。。</td></tr>");
}
});
}
//城市
functionLoadCity(provinceid){
$.ajax({
type:"POST",
url:"ashx/weatherHandler.ashx",
data:"provinceid="+provinceid+"&option=city",
success:function(result){
$(".sel-cityoption").remove();
vararry=result.split('|');
varobj=null;
for(vari=0;i<arry.length;i++){
if(arry[i]!=null&&arry[i]!=""){
obj=arry[i].split(',');
$(".sel-city").append("<optionvalue='"+obj[1]+"'>"+obj[0]+"</option>");
}
}
},
error:function(errorMsg){
$(".result-tabletr").remove();
$(".result-table").append("<tr><td>城市請求出現錯誤,請您稍後重試。。。</td></tr>");
}
});
}
//載入天氣
functionGetWeather(cityid){
$.ajax({
type:"POST",
url:"ashx/weatherHandler.ashx",
data:"cityid="+cityid+"&option=weather",
success:function(result){
$(".result-tabletr").remove();
vararry=result.split('|');
varobj=null;
for(vari=0;i<arry.length;i++){
if(arry[i]!=null&&arry[i]!=""){
if(arry[i].indexOf(".gif")>0){
$(".result-table").append("<tr><td><imagesrc='images/"+arry[i]+"'/></td></tr>");
}
else{
$(".result-table").append("<tr><td>"+arry[i]+"</td></tr>");
}
}
}
},
error:function(errorMsg){
$(".result-tabletr").remove();
$(".result-table").append("<tr><td>天氣數據請求出現錯誤,請您稍後重試。。。</td></tr>");
}
});
}

html代碼:

<body>
<formid="form1"runat="server">
<divclass="head-div">
<table>
<tr>
<td>
<selectclass="sel-provincesel">
</select>
</td>
<td>
<selectclass="sel-citysel">
</select>
</td>
<td>
<inputtype="button"class="btn-search"value="查詢"/>
</td>
</tr>
</table>
</div>
<divclass="result-div">
<tableclass="result-table">
</table>
</div>
</form>
</body>

由於js不支持跨域,直接ajax+ashx一般處理程序(在裡面調用天氣介面)。一般處理程序代碼如下:

usingSystem.Web;
usingSystem;
usingSystem.Collections.Generic;
usingSystem.Linq;
usingSystem.Web;
usingSystem.Text;

namespaceWeatherTest.ashx
{
///<summary>
///weatherHandler的摘要說明
///</summary>
publicclassweatherHandler:IHttpHandler
{
WeatherWsClient.WeatherWSSoapClientclient=newWeatherWsClient.WeatherWSSoapClient();
publicvoidProcessRequest(HttpContextcontext)
{
context.Response.ContentType="text/plain";
string[]result=null;
stringoption=context.Request.Form["option"];
switch(option)
{
case"province":
result=GetProvinces();
break;
case"city":
result=GetCitys(context.Request.Form["provinceid"]);
break;
case"weather":
result=GetWeather(context.Request.Form["cityid"],null);
break;
}
stringstr=ConvertToString(result,option);

context.Response.Write(str);
}
///<summary>
///數組轉字元串
///</summary>
///<paramname="result"></param>
///<paramname="option"></param>
///<returns></returns>
privatestringConvertToString(string[]result,stringoption)
{
StringBuildersb=newStringBuilder();
foreach(stringiteminresult)
{
sb.Append(item+"|");
}
returnsb.ToString();
}

///<summary>
///省份
///</summary>
///<returns></returns>
privatestring[]GetProvinces()
{
returnclient.getRegionProvince();
}
///<summary>
///城市
///</summary>
///<paramname="provinceid"></param>
///<returns></returns>
privatestring[]GetCitys(stringprovinceid)
{
returnclient.getSupportCityString(provinceid);
}
///<summary>
///天氣數據
///</summary>
///<paramname="cityid"></param>
///<paramname="userid"></param>
///<returns></returns>
privatestring[]GetWeather(stringcityid,stringuserid)
{
returnclient.getWeather(cityid,userid);
}

publicboolIsReusable
{
get
{
returnfalse;
}
}
}
}