您的位置:首页 > 编程语言 > ASP

通过一个天气预报案例学习asp.net WebService(基于asp.net MVC)

2013-06-08 20:23 686 查看
本文WebService数据来源:http://www.webxml.com.cn/WebServices/WeatherWebService.asmx

中国气象局 http://www.cma.gov.cn/

本文参考文章:http://zhangkui.blog.51cto.com/1796259/497324 zhangkui的博客

开始本文:

1、创建asp.net MVC程序,作为调用webservice的客户端(使用webForm 、winForm同样道理);

2、添加一个控制器,命名为GetWeather



3、添加“服务引用”,给找到的服务设置一个命名空间,我这里用的是ServiceReferenceWeather



4、以上完成后可以看到



5、打开控制器,添加以下代码

public ActionResult GetWeather()
{
return View();
}

[HttpPost]
public ActionResult GetWeather(FormCollection formCollection)
{
string cityName = formCollection["txtCityName"];
ServiceReferenceWeather.WeatherWebServiceSoapClient w = new WeatherWebServiceSoapClient("WeatherWebServiceSoap");
string[] res = new string[23];
res = w.getWeatherbyCityName(cityName);
ViewData.Model= res;
return View();
}


6、为GetWeather控制器添加一个View,我这里用的Razor模板引擎,用aspx也是一样的



7、将view的默认代码替换为以下代码(其实就是一些html和css,你完全可以自己写)

@{
Layout = null;
}

<!DOCTYPE html>

<html>
<head>
<meta name="viewport" content="width=device-width" />
<title>GetWeather</title>
<style>
div div {
clear: both;
width: 80px;
height: 35px;
line-height: 35px;
color: #b200ff;
font-family: 'Microsoft YaHei';
text-align: right;
float: left;
}

.divContainer {
width: 600px;
height: 35px;
line-height:35px;
}
</style>
</head>
<body>
@using (Html.BeginForm())
{
<span>城市名(支持地级市、直辖市,暂不支持县级市,区等):</span> <input type="text" name="txtCityName" value=" " />
<input type="submit" name="name" value="确定" /><br />
if (ViewData.Model != null)
{
<div class="divContainer">
<div>城市名:</div>
<label>@ViewData.Model[0]</label><span>--</span><label>@ViewData.Model[1]</label>
</div>
<div class="divContainer">
<div>今日天气:</div>
<label>@ViewData.Model[6]</label>
<img src='/Images/@ViewData.Model[8]' alt="Alternate Text" />
<img src='/Images/@ViewData.Model[9]' alt="Alternate Text" />

<label>@ViewData.Model[5]</label>
<label>@ViewData.Model[7]</label>
</div>

<div class="divContainer">
<div>查询时间:</div>
<label>@ViewData.Model[4]</label>
</div>

<div class="divContainer">
<div>明日预报:</div>
<label>@ViewData.Model[13]</label>
<img src='/Images/@ViewData.Model[15]' alt="Alternate Text" />
<img src='/Images/@ViewData.Model[16]' alt="Alternate Text" />

<label>@ViewData.Model[12]</label>
<label>@ViewData.Model[14]</label>
</div>
}
}

</body>
</html>


8、将asp.net MVC的默认路由改为适合本案例的Controller 和action



按F5,将程序运行起来,你可以看到:



输入:比如 扬州



本文完

获取更多数据和帮助,可以访问:http://www.webxml.com.cn/WebServices/WeatherWebService.asmx

该WebService返回的string[]数组包含以下数据,可以用索引访问(如同本文中用索引访问ViewData.Model ):

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐